我想使用 KendoUI 编辑器基本上只允许用户将文本格式化为段落。可能允许粗体和下划线。
我正在努力解决两件事:
- 我想在粘贴时从文本中删除所有 html 格式
- 我想禁用粗体、下划线等的键盘快捷键——即使工具栏元素不存在,它们似乎也能工作。
谢谢!
我想使用 KendoUI 编辑器基本上只允许用户将文本格式化为段落。可能允许粗体和下划线。
我正在努力解决两件事:
谢谢!
为了粘贴唯一的文本,您可以定义一个粘贴处理程序来删除除文本之外的所有内容。这很简单:
$("#editor").kendoEditor({
paste: function (ev) {
ev.html = $(ev.html).text();
}
});
paste
处理程序接收作为参数的事件,该事件包含在正在html
解析的文本中。我们可以使用 jQuery 来获取仅使用的文本$(ev.html).text()
对于删除快捷方式,据我所知,如果您只定义了您想要的工具,那么只有那些快捷方式是活动的。所以如果你说这样的话:
$("#editor").kendoEditor({
tools: [
"italic"
],
paste: function (ev) {
ev.html = $(ev.html).text();
}
});
只有italic
快捷方式<ctrl>+i
可用。如果您将tools
数组留空,则您没有任何数组。
现在可以通过pasteCleanup
选项轻松实现这一点。
见这里:http ://docs.telerik.com/kendo-ui/controls/editors/editor/pasting
对我来说,这是完整的解决方案
pasteCleanup: {
custom: function (html)
{
html = html.replace(/<\s*br\/*>/gi, '');
html = html.replace(/<\s*a.*href="(.*?)".*>(.*?)<\/a>/gi, " $2 (Link - $1) ");
html = html.replace(/<\s*\/*.+?>/ig, '');
html = html.replace(/ {2,}/gi, '');
html = html.replace(/\n+\s*/gi, '');
html = html.replace(" ", '');
html = html.replace(/<.*?>/g, '');
return html;
}
}
Kendo MVC 也为此目的进行了扩展。使用示例:
.PasteCleanup(x => x.KeepNewLines(false))
false
在这种情况下意味着您要清除除新行之外的所有内容。