vue插件实现v-model功能
最近在开发自己的富文本编辑器插件,在开发中遇到了很多问题其中我觉得比较好的问题就是在你定义的插件中实现双向绑定。就好像input中v-model的功能类似。
v-model语法
在vue中我们实现表单的双向绑定时代码一般时这样写的
<input type="text" v-model="value" style="line-height: 30px;"> data () { return { value: '222' } }
可以通过这样的方式实现value的值和输入框中的值双向绑定了。
事实上v-model只是一个语法糖,他的真正实现是这样的
<input type="text" :value="value" @input="value=$event.target.value">
以上代码分几个步骤
1.将输入框的值绑定到变量上,这个是单向绑定,意味着改变变量的值可以改变输入框的值,改变输入框的值不能改变变量的值
2.监听input事件(input输入框都有该事件,当输入内容时自动触发该事件),当输入框输入内容就单向改变变量的值了
自定义编辑器双向绑定
这个是插件的写法content是双向绑定的值 height是指编辑器的高度
<editor v-model="content" :height="editorHeight"></editor>
插件vue的写法
<div v-bind:style="{height: height}" class="editor-box" ref="editor" contenteditable v-html="contentHtml" @input="changeText"></div>
在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 : '<div><br></div>', // 是否在编译 isLocked: true, // 光标位置 lastEditRange: null } }, watch: { value (val) { if (!this.isLocked) { this.contentHtml = this.value; } } }
写到这里大家应该一头雾水这样写有什么用因为还少了一些代码
<div v-bind:style="{height: height}" class="editor-box" ref="editor" contenteditable v-html="contentHtml" @input="changeText" @focus="focusEditor" @blur="blurEditor"></div> // 编辑器失去焦点 blurEditor (event) { this.isLocked = false }, // 编辑器获得焦点 focusEditor (event) { this.isLocked = true },
需要给插件添加两个方法判断编辑器是否正在编辑内容,如果正在编辑中父组件绑定的值不让他重新渲染子组件,这样编辑器中的内容就不会重新赋值了,这样光标就不会每次都跑到前面去了。
小小的一下
•v-bind只能实现单向绑定
•v-model(v-bind+触发的input事件)实现双向绑定
以上所述是长沙网络推广给大家介绍的vue插件实现v-model功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,长沙网络推广会及时回复大家的。在此也非常感谢大家对狼蚁SEO网站的支持!
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程