vue 2.0组件与v-model详解
对此感兴趣的朋友,看看idc笔记做的技术笔记!
前言
大家可能乍一看这个标题,可
这篇文章主要为大家详细介绍了vue 2.0组件与v-model详解,具有一定的参考价值,可以用来参考一下。
对此感兴趣的朋友,看看idc笔记做的技术笔记!
前言
大家可能乍一看这个标题,可能会有疑问:v-model和组件也能扯到一起?在打算写这篇文章的时候,也是这么想的。咱们按简历的那一套STAR法则来梳理一下这篇文章:
情景【Situation】:
编写通用的输入组件时,子组件要绑定到父组件的某个变量上dataA,当父组件要拿到自组件的值时不能通过this.$children.xxx
取值然后付给dataA,
而是父组件可以直接this.dataA
就可以取到当前子组件最新值。
任务【Task】:
实现在父组件直接this.dataA就可以取到当前子组件最新值。
行动【Action】:
首先要了解v-model这个指令,许多认真阅读过完整vue文档的同学可能已经知道了关于v-model。
v-model官方给出的说发是:这其实是一个简写的形式,v-model实际执行的是下面的绑定:
代码如下:
1 2 | <code> <input type= "text" v-bind:value= "dataA" v-on:input= "dataA = $event.target.value" /></code> |
v-model是动态绑定值到value,然后监听input的inpit事件获取值后赋给dataA的一个过程。
在说一下input的value属性,在组件内部要定义一个value的props属性,以便能够动态绑定上父组件传过来的值;
组件内部还要做一件事情:
动态计算(获取和设置)currentValue的值,用到了vue的对象的get和set函数;
讲到这里,我们就可以解决上面的问题了;
首先定义一个通用输入组件:
代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | <code> Vue.component( 'my-component' ,{ template: '<div><input type="text" type="text" v-model="currentValue"/></div>' , data: function (){ return { // 双向绑定值-必须 currentValue:this.value } }, props:[ 'value' ], // 设置value为props属性-必须 computed:{ currentValue: { // 动态计算currentValue的值 get: function () { return this.value; }, set: function (val) { this. $emit ( 'input' , val); } } } })</code> |
在Html里绑定到vue实例的一个字段上;
代码如下:
1 2 3 4 5 | <code> <div id= "demo_01" > <my-component v- for = "(val,key) in postData" v-model= "postData[key]" ></my-component> <button @click= "showValue" >打印对象值</button> </div></code> |
实例里写一个方法
打印一下我们绑定的值;
代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | <code> var demo_01 = new Vue({ el: '#demo_01' , data:{ postData:{ name: '李雷' , age: '80' , describ: '这是一个传奇的人物' } }, methods:{ showValue: function (){ console.log(this.postData) } } });</code> |
是不是以后就不用繁琐冗长的this.$children.xxx
取值方式了?
结果【Result】:
提供了有效的解决了关于输入类组件取值方案,并且已经部署实施。
总结
以上就是关于vue2.0 组件和v-model的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对php教程的帮助。
注:关于vue 2.0组件与v-model详解的内容就先介绍到这里,更多相关文章的可以留意