8

我有<div>一个contentEditable="true"

当我在可编辑的 div 中复制粘贴内容时,粘贴的文本会被包裹到许多不需要的 CSS 中。

例如,这: <p>text text</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 的浏览器不要生成这个?

4

1 回答 1

8

我有同样的问题,加上每个浏览器创建不同的 HTML 的问题。所以我写了一个Sanitize库的 JavaScript 端口:Sanitize.js

Sanitize.js 是一个用 JavaScript 编写的基于白名单的 HTML 清理程序。给定一个可接受元素和属性的列表,Sanitize.js 将从 DOM 节点中删除所有不可接受的 HTML。

看一下示例,我在其中捕获paste事件并随后处理 HTML。

于 2010-08-30T20:58:31.430 回答