vue插件实现v-model功能


Posted in Javascript onSeptember 10, 2018

最近在开发自己的富文本编辑器插件,在开发中遇到了很多问题其中我觉得比较好的问题就是在你定义的插件中实现双向绑定。就好像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功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
javascript getElementsByClassName函数
Apr 01 Javascript
jQuery把表单元素变为json对象
Nov 06 Javascript
jQuery实现带动画效果的二级下拉导航方法
Mar 11 Javascript
JavaScript访问字符串中单个字符的两种方法
Jul 03 Javascript
JavaScript+html5 canvas绘制渐变区域完整实例
Jan 26 Javascript
跨域请求的完美解决方法(JSONP, CORS)
Jun 12 Javascript
jQuery监听浏览器窗口大小的变化实例
Feb 07 Javascript
微信小程序实现购物页面左右联动
Feb 15 Javascript
element-ui表格合并span-method的实现方法
May 21 Javascript
微信小程序授权登陆及每次检查是否授权实例代码
Sep 18 Javascript
原生JavaScript写出Tabs标签页的实例代码
Jul 20 Javascript
javascript实现左右缓动动画函数
Nov 25 Javascript
在Angular中使用JWT认证方法示例
Sep 10 #Javascript
详解vue-router传参的两种方式
Sep 10 #Javascript
详解Vue.js使用Swiper.js在iOS
Sep 10 #Javascript
webuploader分片上传的实现代码(前后端分离)
Sep 10 #Javascript
在Vue 中使用Typescript的示例代码
Sep 10 #Javascript
ES6使用export和import实现模块化的方法
Sep 10 #Javascript
Vuejs 实现简易 todoList 功能 与 组件实例代码
Sep 10 #Javascript
You might like
其他功能
2006/10/09 PHP
PHP生成excel时单元格内换行问题的解决方法
2010/08/26 PHP
PHP系统命令函数使用分析
2013/07/05 PHP
非常全面的php日期时间运算汇总
2015/11/04 PHP
PHP模拟post提交数据方法汇总
2016/02/16 PHP
php实现中文转数字
2016/02/18 PHP
Yii支持多域名cors原理的实现
2018/12/05 PHP
jquery操作checkbox实现全选和取消全选
2014/05/02 Javascript
js调试系列 断点与动态调试[基础篇]
2014/06/18 Javascript
JavaScript数据推送Comet技术详解
2016/04/07 Javascript
JavaScript的MVVM库Vue.js入门学习笔记
2016/05/03 Javascript
AngularJS 霸道的过滤器小结
2017/04/26 Javascript
javascript完美实现给定日期返回上月日期的方法
2017/06/15 Javascript
把JavaScript代码改成ES6语法不完全指南(分享)
2017/09/10 Javascript
Vue 滚动行为的具体使用方法
2017/09/13 Javascript
Node绑定全局TraceID的实现方法
2019/11/14 Javascript
[02:36]DOTA2上海特锦赛 回忆电竞生涯的重要瞬间
2016/03/25 DOTA
Python 数据处理库 pandas进阶教程
2018/04/21 Python
浅析pandas 数据结构中的DataFrame
2019/10/12 Python
pygame实现飞机大战
2020/03/11 Python
如何利用python检测图片是否包含二维码
2020/10/15 Python
CSS3实现头像旋转效果
2017/03/13 HTML / CSS
英国标准协会商店:BSI Shop
2019/02/25 全球购物
写好求职信第一句话的技巧
2013/10/26 职场文书
学前教育求职自荐信范文
2013/12/25 职场文书
初三学生个人自我评定
2014/04/06 职场文书
幼儿教师师德承诺书
2014/05/23 职场文书
2014司机年终工作总结
2014/12/05 职场文书
中国合伙人观后感
2015/06/02 职场文书
我是特种兵观后感
2015/06/11 职场文书
求职信:会计求职的写作技巧
2019/04/24 职场文书
mysql定时自动备份数据库的方法步骤
2021/07/07 MySQL
使用pandas生成/读取csv文件的方法实例
2021/07/09 Python
阿里云服务器Ubuntu 20.04上安装Odoo 15
2022/05/20 Servers
Redis基本数据类型String常用操作命令
2022/06/01 Redis
GoFrame基于性能测试得知grpool使用场景
2022/06/21 Golang