HTML编辑器

在线 HTML 编辑器原理
从eWebEditor到 FCKeditor现在有很多很多的在线编辑器了,功能都很强,很多,但是其基本原理却都很简单我发现的编辑器主要有3大类,我总结下,把各自的优缺点都写下:
1.直接用textarea 标签优点:速度快,提交方便,可以用UBB标签来弥补不能所见所得缺点:不直观,功能非常少
2.用DIV或者TABLE的CONTENTEDITABLE 标签,属性来让一个区域可以编辑优点:可以很直观,可以做各种效果缺点:此标签在mozilla下不可用,只适合IE浏览器,且对js要求高
3.用iframe或者frame的中的document的document.designMode ="On" 来实现可编辑优点:具有上面第二条的全部优点,并且还多浏览器比如FF等支持缺点:对js要求高
4.第三种在线编辑器的原理:为什么能实现在线编辑呢?  首先需要ie 的支持,在 ie 5.5以后就有一个编辑状态,就是利用这个编辑状态,然后用javascript 来控制在线编辑的。
下面给出一个简短的例子:首先要有一个编辑框,这个编辑框其实就是一个 可编辑状态的 网页,我们这里用iframe 来建立编辑框
<IFRAME id=HtmlEdit style="WIDTH: 100%; HEIGHT: 296px" marginWidth=0 marginHeight=0> </IFRAME>
并且在 加上javascript 代码来指定 HtmlEdit 有编辑功能:
         
   function document.onreadystatechange(){  
                  HtmlEdit.document.designMode="On";
  }
HtmlEdit.document.body.innerHTML 
 这句可以获得 HtmEdit 里面的html代码. 一般的我们会用这样的javascript 将 iframe 里的内容传递给一个textarea 然后提交给服务器处理.
function getIframeData(){    document.form1.test.value=HtmlEdit.document.body.innerHTML; } function sentIframeData({   
 HtmlEdit.document.body.innerHTML=document.form1.test.value;
}
var sel = HtmlEdit.document.selection.createRange();
而这一句可以获得选取的焦点:
下面我就演示一个完成的例子. 一个拥有加粗功能的在线编辑器,有兴趣的朋友可以在此基础上完成其他功能!!
<html>
 <head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
 <script language="javascript">
function getIframeData(){  
document.form1.test.value=HtmlEdit.document.body.innerHTML;
}
function sentIframeData(){  
HtmlEdit.document.body.innerHTML=document.form1.test.value;
}
function doB(){  
 HtmlEdit.focus();  
 var sel = HtmlEdit.document.selection.createRange();  
 insertHTML("<b>"+sel.text+"</b>");
 }
 function insertHTML(html) {
 
if (HtmlEdit.document.selection.type.toLowerCase() != "none" ){  
  HtmlEdit.document.selection.clear() ;  
}  
HtmlEdit.document.selection.createRange().pasteHTML(html) ;
 }
function document.onreadystatechange(){    
HtmlEdit.document.designMode="On";
}
</script>
</head>
<body>
<form action="test.asp?act=add" method="post" name="form1">
  <IFRAME id=HtmlEdit style="WIDTH: 100%; HEIGHT: 296px" marginWidth=0 marginHeight=0></IFRAME>
<textarea name="test" rows="10" id="test" style="width:100%;"></textarea>
 <br/> <input type="submit" name="Submit" value="提交">
<input type="button" value="iframe->textarea">
<input type="button" value="textarea->iframe">
<input type="button" value="B">
 </form>
 </body>
</html>
5. 现在常用的有:a. FCKeditor 编辑器(最新版本: 2.3.1站点: http://www.fckeditor.net 演示 http://www.fckeditor.net /demo特点:开源、免费 )
 
b. eWebEditor 在线编辑器 (最新版本:4.0站点: http://www.ewebsoft.com/ 演示: http://ewebeditor.webasp.net/demo.asp 特点:国产、易用)

3. WYSIWYG Editor 在线编辑器注:WYSIWYG是What You See Is What You Get(所见即所得)首字母组合(最新版本:2.9.7 站点: http://www.innovastudio.com/editor.asp 演示: http://www.innovastudio.com/editor_tutorial.asp 特点: 物有所值)

 一个简单的演示:http://blog.csdn.net/jaylongli/archive/2008/06/26/2589109.aspx鼠标可以直接点击

你可能感兴趣的:(JavaScript,html,function,iframe,fckeditor,button)