CKEditor is an online rich text editor that can be embedded inside web pages. It is a WYSIWYG (What You See Is What You Get) editor which means that the text edited in it looks as similar as possible to the results end users will see after the document gets published. It brings to the Web popular editing features found in desktop word processors such as Microsoft Word and OpenOffice.org Writer. – Source: CKEditor DocumentationBefore knowing about the CKEditor (previously FCKEditor), I was wondering if there is a tool in web that makes the document customizable. That means I was searching for web tool with which I can make sentences Bold, Italic or Numbered and Bulleted, or I can change Font size, font family, text color, or insert links, photos and many more without using HTML tags. Finally I came up with CKEditor which solves my problem. CKEditor is very easy to use and have very beautiful and user friendly interface like MS office and Open office. In this tutorial I am going through all steps required to install and configure the CKEditor and show you a working example with Javascript.
Installation
- Download the latest version of the editor from CKEditor official website: http://ckeditor.com/download
- Extract (decompress) the downloaded archive to a directory called
ckeditor
in the root of your website.
Step 1: Including CKEditor in page
CKEditor actually replaces the textarea in HTML page. To do this you must include the reference to javascript file ckeditor.js in the head section of the page.
1
2
3
| < head > < script type = "text/javascript" src = "/ckeditor/ckeditor.js" ></ script > </ head > |
1
| |
To create the CKEditor instance, first create a text area like this
1
| < textarea id = "ck1" name = "ck1" >Initial value</ textarea > |
1
2
3
| < script type = "text/javascript" > CKEDITOR.replace( 'ck1' ); </ script > |
This is all about replacing textarea with CKEditor. You can save the content of CKEditor both by client side and server side data handling. In server side you can use the following PHP code
1
2
3
| <?php $content = $_POST [ 'ck1' ]; ?> |
In client side you can use JavaScript to do this
1
2
3
| < script type = "text/javascript" > var data = CKEDITOR.instances.ck1.getData(); </ script > |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
| < html > < head > < title >CKEditor with Javascript</ title > < script type = "text/javascript" src = "ckeditor/ckeditor.js" ></ script > </ head > < body > < form action = "#" method = "post" id = "form1" > < textarea id = "ck1" ></ textarea > < script type = "text/javascript" > CKEDITOR.replace('ck1'); </ script > </ form > </ body > </ html > |
Output
Customizing the CKEditor
You may not need all the toolbar available in default settings. You can filter the toolbar by using following code snippet
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
| CKEDITOR.replace('ck1', { toolbar : [ { name: 'document', items : [ 'Preview' ] }, { name: 'clipboard', items : [ 'Cut','Copy','Paste','PasteText','PasteFromWord','-','Undo','Redo' ] }, { name: 'editing', items : [ 'Find','Replace','-','SelectAll','-','Scayt' ] }, { name: 'insert', items : [ 'Image','Table','HorizontalRule','Smiley','SpecialChar','PageBreak'] }, '/', { name: 'styles', items : [ 'Styles','Format','Font','FontSize' ] }, { name: 'basicstyles', items : [ 'Bold','Italic','Strike','-','RemoveFormat' ] }, { name: 'paragraph', items : [ 'NumberedList','BulletedList','-','Outdent','Indent','-','Blockquote' ] }, { name: 'links', items : [ 'Link','Unlink','Anchor' ] }, { name: 'colors', items : [ 'TextColor','BGColor' ] }, { name: 'tools', items : [ 'Maximize','-','About' ] } ], }); |
1
2
3
4
5
6
7
| < script type = "text/javascript" > CKEDITOR.replace('ck1', { width: "600px", height: "300px" }); </ script > |
0 comments:
Post a Comment