电竞比分网-中国电竞赛事及体育赛事平台

分享

博客園 - 小橋 - 在線HTML編輯器原理

 fantongx 2006-06-10
為什么能實(shí)現(xiàn)在線編輯呢?  首先需要ie 的支持,在 ie 5.5以后就有一個編輯狀態(tài),就是利用這個編輯狀態(tài),然后用javascript 來控制在線編輯的。
下面給出一個簡短的例子:

首先要有一個編輯框,這個編輯框其實(shí)就是一個 可編輯狀態(tài)的 網(wǎng)頁,我們這里用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 里的內(nèi)容傳遞給一個textarea 然后提交給服務(wù)器處理.

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(); 而這一句可以獲得選取的焦點(diǎn):

下面我就演示一個完成的例子. 一個擁有加粗功能的在線編輯器,有興趣的朋友可以在此基礎(chǔ)上完成其他功能!!

<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>

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點(diǎn)擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多