最近在开发自己的富文本编辑器插件,在开发中遇到了很多问题其中我觉得比较好的问题就是在你定义的插件中实现双向绑定。就好像input中v-model的功能类似。
v-model语法:
在vue中我们实现表单的双向绑定时代码一般时这样写的:
data () {
return {
value: '222'
}
}
可以通过这样的方式实现value的值和输入框中的值双向绑定了。
事实上v-model只是一个语法糖,他的真正实现是这样的:
以上代码分几个步骤:
自定义编辑器双向绑定
这个是插件的写法:content是双向绑定的值 height是指编辑器的高度
插件vue的写法:
在div中设置contenteditable属性时把div设置成可编辑的输入框,v-html是给编辑器单向绑定变量contentHtml值,input方法获取编辑器的内容并且返回给父元素的input方法:
changeText () {
const htmlString = this.$refs.editor.innerHTML
this.$emit('input', htmlString)
},
其他问题:
光是这样是不能够解决问题的,编辑器你会出现每次输入的时候都会跳到开头位置:怎么解决呢?不多说上代码:
props: {
value: {
type: String,
default: ''
},
height: {
type: String,
default: 'auto'
}
},
data () {
return {
// 编辑器内容
contentHtml: this.value || this.value === 0 ? this.value : '
',
// 是否在编译
isLocked: true,
// 光标位置
lastEditRange: null
}
},
watch: {
value (val) {
if (!this.isLocked) {
this.contentHtml = this.value;
}
}
},
写到这里大家应该一头雾水这样写有什么用:因为还少了一些代码:
// 编辑器失去焦点
blurEditor (event) {
this.isLocked = false
},
// 编辑器获得焦点
focusEditor (event) {
this.isLocked = true
},
需要给插件添加两个方法判断编辑器是否正在编辑内容,如果正在编辑中父组件绑定的值不让他重新渲染子组件,这样编辑器中的内容就不会重新赋值了,这样光标就不会每次都跑到前面去了。
小小的总结一下:
如果大家有什么意见或建议希望大家在评论区多多交流,谢谢。