vue实现自定义组件的v-model双向数据绑定
如果您发现本文排版有问题,可以先点击下面的链接切换至老版进行查看!!!
vue实现自定义组件的v-model双向数据绑定
<input type="text" v-model="username"> 用户名:{{username}}
其实v-model是一种语法糖,我们要知道它完整的写法才能更好的利用自己vue的理解来深刻理解v-model
上面的语句其本质是下面的:
<input type="text" :value="username" @input="username = $event.target.value"> 用户名:{{username}}
其实我们的自定义组件也是可以实现v-model的,它默认用的属性就是value,事件名为input
Vue.component('child', {
templage: `
<input :value="myName" @input="$emit('input', $event.target.value)"/>
`,
props:['value'] //这个必然是需要的吗
})
在父组件中我们就这么用
<child v-model="userName"></child>
这样的用法适合了解v-model的原理,但是其实一般我们用的不多。怎么说呢,我们一般做项目的时候为用的第三方UI库,一些双向数据绑定什么的做的好好的,但是我们还是经常需要基于这些UI库的组件进行二次封装,那样才能更好的满足自己项目的需要嘛,这时候我们可能需要自己封装组件,把UI库的组件包一下,以element-ui为例(此示例只是用于演示)
Vue.component('child', {
templage: `
<el -cascader
:placeholder="placeholder"
:options="options"
:show-all-levels="false"
@change="handleChangeToInput">
</el>
`,
props: {
options: {
type: Array,
default: function() {
return [];
}
},
placeholder: {
type: String,
default: "请选择"
},
value:[String,Array]
},
handleChangeToInput(value) {
//直接用emit input事件,方便父组件直接使用v-model实现双向数据绑定
this.$emit("input", value);
}
})
element-ui官方给的用法里面写的事件是change事件(源码里面好像有input事件),通过上面的‘二次封装’我们就实现让child组件可以用v-model了
我们可以继续愉快的用
<child v-model="userName"></child>
注:实际上在较新的版本的vue里面已经支持更改v-model默认用的value属性名和input事件名了
- 分类:
- Web前端
更新时间:
相关文章
支持取消单选组件vue版
原生的单选就是 <input type="radio"/> ,正常情况在 name 相同的单选之间只能选一个,如果只有一个单选框的情况下,一经选中是无法自己取消的,和 阅读更多…
从vuecli3学习webpack记录(一)vue-cli-serve机制
最近看了看vuecli3,把自己的学习记录下来。 首先看入口 npm run dev 即是 vue-cli-service serve ,之所以能运行 vue-cli-service 命令,就是 阅读更多…
前端框架vue+wordpress做后端
目前正在利用闲暇时捯饬一下自己的博客,毕竟这么久没有维护了,wordpress是可以用restful API来获取数据的,决定前端用vue实现,目前正在尝试中,今天做了其中很小的一部分,就是博客目录 阅读更多…
Vue在chrome44偶现点击子元素事件无法冒泡
公司的一个项目大致是这样的:一个左侧列表,点击左侧列表的文章标题,右侧展开该文章对应的内容的。 现在的问题出现在极少部分客户有时左侧的标题,无法打开对应的右侧的内容,给人的改进就是‘卡’、点不动、点 阅读更多…
element-ui表单源码解析之el-input
关于表单校验el-input做的主要工作就是跟el-form-item交互,把input的相关事件发送给el-form-item,上一篇已经讲到在el-form-item的mounted的生命周期里 阅读更多…
用个数组来理解vue的diff算法(一)
原文地址: 道招网 的 用个数组来理解vue的diff算法(一) Vue使用的diff算法,我相信用vue的估计都听过,并且看到源码的也不在少数。 先对下面的代码做下说明: 由于这里用 阅读更多…