HTML编辑器原理

为什么能实现在线编辑呢?  首先需要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 "  onClick = " getIframeData() " >
< input type = " button "  value = " textarea->iframe "  onClick = " sentIframeData() " >
< input type = " button "  value = " B "  onClick = " doB() " >
</ form >
</ body >
</ html >
在线编辑器在我们日常的项目开发中非常有用(如新闻系统),它可以方便地实现文章的在线编辑,省掉了FrontPage等工具。那么是怎样实现浏览器在线编辑功能的呢?  首先需要IE的支持,在IE5.5以后就有一个编辑状态. 就是利用这个编辑状态,然后用javascript来控制在线编辑的。
首先要有一个编辑框,这个编辑框其实就是一个可编辑状态的网页, 我们用iframe来建立编辑框。
< IFRAME id = “HtmlEdit” style = " WIDTH: 100%; HEIGHT: 296px "  marginWidth = 0 ” marginHeight = 0 ></ IFRAME >
并且在加上javascript代码来指定HtmlEdit有编辑功能(下面提供完整的原代码):
   < script language = " javascript " >
     var editor;
     editor 
=  document.getElementById( " HtmlEdit " ).contentWindow;
     
     
// 只需键入以下设定,iframe立刻变成编辑器。
     editor.document.designMode  =   ' On ' ;
     editor.document.contentEditable 
=   true ;
     
     
// 但是IE与FireFox有点不同,为了兼容FireFox,所以必须创建一个新的document。
     editor.document.open();
     editor.document.writeln(
' <html><body></body></html> ' );
     editor.document.close();

     
// 字体特效 - 加粗方法一 
     function addBold()
     {
     editor.focus();
     
// 所有字体特效只是使用execComman()就能完成。
     editor.document.execCommand( " Bold " false null );
     }
     
// 字体特效 - 加粗方法二 
     function addBold()
     {
     editor.focus();
     
// 获得选取的焦点
     var sel  =  editor.document.selection.createRange();
     insertHTML(
" <b> " + sel.text + " </b> " );
     }
     function insertHTML(html)
     {
         
if  (editor.document.selection.type.toLowerCase()  !=   " none " )
         {
         editor.document.selection.clear() ;
         }
         editor.document.selection.createRange().pasteHTML(html) ; 
     }

  
</ script >

转载于:https://www.cnblogs.com/cdutedu/archive/2009/05/26/1488832.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值