在非vue项目中使用vue-quill-editor实现粘贴纯文本功能
在一个非vue项目中,我们需要使用vue-quill-editor,并实现粘贴纯文本功能。具体要求如下:
- 粘贴富文本时,将其转换为纯文本。
- 插入文本后,光标应移至插入文本后方。
- 文本样式不受当前光标位置样式影响。
解决方案
可以使用quill提供的clipboard.addmatcher方法来自定义粘贴文本。具体步骤如下:
修改后的代码示例:
initquill() { const node_type = { element_node: 1 }; const quill = this.$refs.myquilleditor.quill; quill.clipboard.addmatcher(node_type.element_node, function (node, delta) { const plaintext = node.innertext; const delta = quill.import("delta"); return new delta().insert(plaintext); }); },
注意,原先使用inserttext方法可能会受到外部样式的影响。而delta api可以从头开始进行编辑,而不受当前操作索引的影响。
完整代码示例如下:
pasteListenerCb(event) { event.preventDefault(); let paste = (event.clipboardData || window.clipboardData).getData("text"); this.clipboardData = paste; const pasteLength = paste.length; const quill = this.$refs.myQuillEditor.quill; const index = quill.selection.savedRange.index; quill.updateContents([ { retain: index, }, { insert: paste, }, ]); },