萬盛學電腦網

 萬盛學電腦網 >> 網頁制作 >> Html5 >> html在線編輯器原理

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>

好了,html在線編輯器原理內容就給大家介紹到這裡了。希望大家繼續關注我們的網站!

相關推薦:

html在線編輯器使用 

copyright © 萬盛學電腦網 all rights reserved