html contenteditable

时间:2023-02-12 19:46:18

  contenteditable 是html中的一個屬性,在HTML中,某些元素設置 contenteditable='true'  屬性時可以開啟該元素的編輯模式,contenteditable 可以讓div 或整個網頁,或者span等等元素設置為可寫,我們最常用的是 input 、textarea 文本輸入元素來輸入內容,但這些也只能夠輸入純文本,而 contenteditable 開啟後能夠輸入html內容。

如果想在整個網頁可編輯,請在 body 標籤內設置 contenteditable

contenteditable 已在 html5 標準中得到有效的支持

  使用方法:

  <div contenteditable='true'></div>

  HTML5 中的解釋與規定:

contenteditable是一個枚舉類型的屬性,可供選擇的值有空字符串、 true、 false 或 inherit (默認) 。
當為空字符串時,效果和true一致。
當一個元素的 contenteditable 狀態為 true (contenteditable 屬性為空字符串,或為true,或為inherit且其父元素狀態為true)時,意味著該元素是可編輯的。否則該元素不可編輯。 
注意:HTML5 與 HTML4的不同,對於contenteditable HTML5 是趨於xhtml,使用的是全小寫 contenteditable,而 HTML4使用的是 contentEditable
 
在最近的一次網站開發的過程中,有一個頁面需要給用戶填寫一些要提交的文本信息,剛開始的時候是用 textarea ,功能就需要讓用戶可以插入圖片,若只是填寫純文本。textarea 已經可以做到,但是現在是要用戶能夠上傳圖片並且插入編輯框 ,剛開始的思路是用一個iframe把圖片上傳了,當用戶點擊確定的時候,。獲取裏面已經上傳的圖片地址。然後用文本的格式做個標識添加到 textarea 裏面,像 [iamges:http://....jpg/] ,點擊取消的時候就用 ajax 把圖片地址傳到 php 將這些圖片從服務器端刪除。基本的思路簡單明了,但是我該怎麼去獲取到要插入文本的位置呢,於是我查找相關資料,查到後我把文章轉到了我的博客裏面:http://www.cnblogs.com/helin/p/3401810.html
似乎離我想要的效果越來越近了,不過後來發現如果是這樣的方式去實現的話,有兩個缺點,一是用戶體驗不好,用戶當然想直接就在文本框裏面顯示,這樣好排版還有操作,看起來也好,若就一條標識字符串。很容易就被截開幾段在中間再插入內容。這樣一來,到時候顯示就成問題了。第二個就是 textarea默認不是自適應高度的,。也就是說你如果內容一多了,。文本框不會往下拉,那就會出現滾動條,看起來也不好看,想要自適應,用js去實現也不是不可以,但有沒有更好的辦法呢。既能直接插入html內容,。又可以自適應高度,我不需要像文本編輯器那些一樣,功能那麼的強大。我只要一個最最最簡單的,可以插入圖片,可以自適應高度就可以了,。於是又要一輪的搜索資料了,不料印象中記得html 元素有個屬性是可以讓元素開啟編輯模式的,然後到QQ空間裏面查看了一下人家的是怎麼做到插入圖片的,讓我記起來了,contenteditable 這個屬性,哈哈,這樣太好了,這是一個好的開始,。那現在的問題就是把textarea 用一個元素替換,再設置一下 contenteditable 屬性,我選擇了div,給它設置了一個最小高度。
現在就可 以直接把上傳好返回的圖片地址或者加進來的遠程的圖片地址直接封閉成html的形式插入到編輯框裏面了。但是div在可編輯狀態下面並不能像textarea 那樣子獲取到編輯框的焦點到底在哪個位置上面,此時,我用到了一個 javascript 裏面的 execCommand 方法,這個方法的一些說明在我的博客:http://www.cnblogs.com/helin/p/3433357.html
document.execCommand('InsertImage', false,imgsrc);

  現在開始有點樣子了,但是除了圖片還有一些基本的排版的html標籤之外,我不想用戶過多的插入一些其他的html。例如字體加粗,下劃線等,也就是雖然我沒有給用戶提供更多的操作這些功能的按鈕,但是防止不了用戶去複製別人的html,然後粘貼進來,所以我要想辦法做一些過濾,這時候我應該要監聽粘貼命令:

if(divEdit.addEventListener){
divEdit.addEventListener("paste",pasteFilter,false);
}else{//IE
divEdit.attachEvent("onpaste",pasteFilter);
}

  一但有這個操作,我就要確保在內容粘貼出來前或者後進行一些處理:

function pasteFilter(){
var clipb = event.clipboardData || window.clipboardData;
try{
var cHtml = clipb.getData('text/html');
cHtml = HtmlFilter(cHtml);
document.execCommand('inserthtml', false,cHtml);
event.preventDefault;
event.returnValue = false;
}catch(e){//IE下面的操作
setTimeout(function(){editDiv.innerHTML = HtmlFilter(editDiv.innerHTML);},1);
}
}

  上面這一步我有分了兩部分,在ie外的其他瀏覽器下面,(當然我只測試過firefox,chrome)try裏面適合不是ie瀏覽器下面的,因為在ie下面javascript 的 clipboardData 對象的 getData方法裏面不支持 text/html ,只支持text ,而且在ie下面,也不支持 execCommand 裏面的inserthtml 參數, 所以在我沒有找到其他更好辦法之前,我也只能做這樣的處理,ie下面我用到了setTimeout的方法,原理就是在粘貼數據的那一刻,同時執行HtmlFilter這個方法,對編輯框裏面的html作過濾,這個方法有不好之處就是當粘貼那一刻,用戶是能看到粘貼過來的樣式等等效果的,只不過以最快的速度再一次將編輯框裏面的內容用js去進行一遍的過濾罷了,這方法雖然不好,但基本能達到我現在想要的要求。

function HtmlFilter(html){
html = html.replace(/(style|class|id)[=\s]+?".*?"/ig,'');
html = html.replace(/<\!--(Start|End)Fragment-->/ig,'');
return html;
}

  當然,用js過濾一遍,這只不過適合於大多數的情況下,若用戶提交了沒有經過過濾的html內容,這時候,也只能夠在服務器端進行最終的過濾了。

  

html contenteditable的更多相关文章

  1. IOS中div contenteditable&equals;true无法输入

    在IOS中<div contenteditable="true"></div>中点击时可以弹出键盘但是无法输入.加一个样式-webkit-user-sele ...

  2. 苹果手机IOS中div contenteditable&equals;true 仿文本域无法输入编辑

    问题: 在苹果手机IOS中 contenteditable="true" 做文本域输入,点击可以弹出键盘但是无法输入,安卓都正常. 经测试后,记得加一个样式 -webkit-use ...

  3. H5之contenteditable

    场景: <div id='content' contenteditable='true' > hello </div> <button id='caret'>设置光 ...

  4. contentEditable属性设置是否可编辑元素的内容

    在HTML5中在标签新添加了一个属性contentEditable可以设置标签内的内容是否可以编辑: 设置contenteditable="true"标签内的元素(内容)可以编辑 ...

  5. contenteditable

    http://www.w3school.com.cn/tags/att_global_contenteditable.asp 做编辑器经常用这个属性 使得整个编辑区域所见所得 http://www.c ...

  6. div contenteditable placeholder

    contenteditable型的编辑框,实现placeholder的方式有两种 第一种,Css的实现方式: <!DOCTYPE html> <html lang="en& ...

  7. div的contenteditable和placeholder蹦出的火花

    今天在做手机端发布描述内容时,需要实现换行,还需要有plachholder. 在文本框中换行自然想到了textarea. 问题似乎已经解决了,但是当内容发布后,在html中显示换行都丢失了. 这个时候 ...

  8. Text selection in div&lpar;contenteditable&rpar; when double click

    背景: 在最近项目中,碰到一个问题:有一个可编辑的div需要双击时可编辑,blur或者回车时将编辑结果保存.你可能注意到双击时,文字会被选中,可编辑区域不会focus到光标位置.考虑到兼容性问题,写了 ...

  9. contenteditable 属性

    定义和用法 contenteditable 属性规定是否可编辑元素的内容. 语法 <element contenteditable="value"> 属性值 值 描述 ...

随机推荐

  1. 用TypeScript开发了一个网页游戏引擎,开放源代码

    最开始学习电脑编程的原动力之一就是想自己编写游戏,一方面很好奇这些游戏是怎么做出来的,另一方面觉得有些地方设计的不合理,希望电脑游戏既能让人玩的有趣,又不浪费时间. 学校五年,毕业十年,学用了十多种编 ...

  2. struts2简单示例

    今天写一个struts2的例子,目的是为了让大家明白struts2的基本流程,其实框架没有大家想象的那么难,说白了struts2的本质就是一个大的Servlet,即原本需要提交到Servlet处理的部 ...

  3. centos6&period;5 安装python2&period;7&period;5

    1. 下载python2.7.5,保存到 /data/http://www.python.org/ftp/python/ 2. 解压文件tar xvf Python-2.7.5.tar.bz2 3. ...

  4. 新生赛(2) problem 2 丁磊养猪

    Problem B Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 32768/32768K (Java/Other) Total Sub ...

  5. Flink-Kafka-Connector Flink结合Kafka实战

    戳更多文章: 1-Flink入门 2-本地环境搭建&构建第一个Flink应用 3-DataSet API 4-DataSteam API 5-集群部署 6-分布式缓存 7-重启策略 8-Fli ...

  6. php 获取 两个时间戳之间 相隔 【多少年】 【 多少个月】 【多少天】 【 多少个小时】 【多少分】【 多少秒 】

    /** * 返回两个时间的相距时间,*年*月*日*时*分*秒 * @param int $one_time 时间戳一 大的时间戳 * @param int $two_time 时间戳二 小的时间戳 * ...

  7. 【MySQL】解决You can&&num;39&semi;t specify target table &&num;39&semi;user&lowbar;cut&lowbar;record&lowbar;0413&&num;39&semi; for update in FROM clause

    问题 You can't specify target table 'user_cut_record_0413' for update in FROM clause 原因 待更新/删除的数据集与查询的 ...

  8. 1083&period; List Grades &lpar;25&rpar;-简单的排序

    给定区间[L,R],给出在这区间之内的学生,并且按照他们的成绩非升序的顺序输出. #include <iostream> #include <cstdio> #include ...

  9. openerp学习笔记 视图继承(tree、form、search)

    支持的视图类型:form.tree.search ... 支持的定位方法:                  <notebook position="inside"> ...

  10. Git本地仓库与远程github同步的时候提示fatal&colon; remote origin already exists 错误解决办法

    Git本地仓库与远程github同步的时候提示fatal: remote origin already exists 错误解决办法 1.git在本地的电脑创建了仓库,要远程同步github的仓库.使用 ...