我有一个< div>有contentEditable =“true”.
当我在可编辑div中复制粘贴内容时,粘贴的文本会被包装到许多不需要的CSS中.
例如,这个:
< p>文字文字< / p>
变为:
<p style="margin-top: 0px; margin-right: 0px; margin-bottom: 0px; margin-left: 0px; padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; border-top-width: 0px; border-right-width: 0px; border-bottom-width: 0px; border-left-width: 0px; border-style: initial; border-color: initial; outline-width: 0px; outline-style: initial; outline-color: initial; font-size: 17px; vertical-align: baseline; background-image: initial; background-attachment: initial; background-origin: initial; background-clip: initial; background-color: transparent; background-position: initial initial; background-repeat: initial initial; ">text text</p>
我理解浏览器(目前的情况下是谷歌浏览器)试图变得聪明,但最终我完全无关紧要且不需要的CSS.
有没有办法告诉基于WebKit的浏览器不生成这个?
解决方法
我遇到了同样的问题,加上每个浏览器创建不同HTML的问题.所以我写了一个
Sanitize库的JavaScript端口:
Sanitize.js
Sanitize.js是一个用JavaScript编写的基于白名单的HTML清理程序.给定可接受元素和属性的列表,Sanitize.js将从DOM节点中删除所有不可接受的HTML.
看一下示例,我捕获粘贴事件并在之后处理HTML.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。