在div中使用contenteditable=”true”可以到达模拟输入框的效果,然则当我们复制其他网页内容进去的时刻,会发现连带的样式也一起复制进去了。很明显我们不需要复制富文本样式,那么若何过滤这些标签呢?
查阅资料,发现若是只保证支持HTML5的webkit内核浏览器,现在有一些方式如下:
方式一:
<div contenteditable="plaintext-only" id="content"></div>
方式二:基于css
user-modify: read-write-plaintext-only; -webkit-user-modify: read-write-plaintext-only
若是在非 webkit 的内核,我们需要思量使用js来实现,首先想到的是:
var d= document.getElementById( "content" ); document.addEventListener( "keydown", function() { d.innerHTML = d.innerHTML.replace( /<[^>]*>/g, "" ); });
发现效果同上面大要一样,这样虽然能过滤样式,然则有许多问题,好比光标始终在首位、输入框不能插入脸色、换行符失效等问题。 上网查了一下别人是怎么做的发现可以通过修改复制事宜来过滤样式:
function pasteFilter(e){ e.preventDefault(); var text = null; //获得剪贴板中的文本 if(window.clipboardData && clipboardData.setData) { // IE text = window.clipboardData.getData('text'); }else{ try{ text = (e.originalEvent || e).clipboardData.getData('text/plain'); }catch(e){ return; } }; if (document.body.createTextRange) { if (document.selection) { textRange = document.selection.createRange(); } else if (window.getSelection) { sel = window.getSelection(); var range = sel.getRangeAt(0); // 建立暂且米素,使得TextRange可以移动到准确的位置 var tempEl = document.createElement("span"); tempEl.innerHTML = "&#FEFF;"; range.deleteContents(); range.insertNode(tempEl); textRange = document.body.createTextRange(); textRange.moveToElementText(tempEl); tempEl.parentNode.removeChild(tempEl); }; textRange.text = text; textRange.collapse(false); textRange.select(); } else { // Chrome之类浏览器 document.execCommand("insertText", false, text); }; }; var d= document.getElementById( "content" ); d.addEventListener("keydown",function(e){ if (e.ctrlKey || e.metaKey) { if(e.keyCode==117){ pasteFilter(e); } } },false);
1.阿里云: 本站现在使用的是阿里云主机,平安/可靠/稳固。点击领取2000米代金券、领会最新阿里云产物的种种优惠流动点击进入
这些搔扰大家的联系电话 现阶段打让我们的电话骚扰,除开一般的手机号码、座机号码,便是以400、800、1010、95开始的号。 在大伙儿的印像中,这种号一般是金融机构、证劵、大企业、大型企业全部,比较...
【网信办约谈网易:存严重导向、违法转载新闻信息等问题】今天,国家互联网信息办公室有关业务局负责人约谈了网易公司负责人,指出网易存在严重导向问题,并存在违法转载新闻信息等问题。强调从事互联网新闻信息服务...
加强宪法学习,为青少年扣好“人生第一颗扣子” “人生的扣子从一开始就要扣好。”青少年法治教育的成效关系依法治国的走向、深度和持久性,如何让法治种子在校园开花结果,成为成都市推进青少年法治教育...
• ds7002.PDF (钓饵PDF文件) if (isset($_SERVER['HTTP_X_FORWARDED_FOR']))数据安全办理遵从的道路图1. 加载R3层根底模块“subsyste...
“如何找私人导游伴游-【孔萍】” 本人商务可以说商务企业也是愈来愈沒有整体规划:lmhack.com/fl-kj/1791.html.商务们的线上与线下主题活动都是有许多 ,“本人商务可以说商务企业也...
本文目录一览:...