vue2.0 组件和v-model

本文适合初学组件编写的同窗阅读。vue

乍一看这个标题,可能会有疑问:v-model和组件也能扯到一块儿?函数

我打算写这篇文章的时候,也是这么想的。我们按简历的那一套STAR法则来梳理一下这篇文章:post

情景【Situation】:this

编写通用的输入组件时,子组件要绑定到父组件的某个变量上dataA,当父组件要拿到自组件的值时不能经过this.$children.xxx取值而后付给dataA,spa

而是父组件能够直接this.dataA就能够取到当前子组件最新值。双向绑定

任务【Task】:code

实如今父组件直接this.dataA就能够取到当前子组件最新值。component

行动【Action】:对象

首先要了解v-model这个指令,许多认真阅读过完整vue文档的同窗可能已经知道了关于v-model。blog

v-model官方给出的说发是:这实际上是一个简写的形式,v-model实际执行的是下面的绑定:

<input type="text" v-bind:value="dataA" v-on:input="dataA = $event.target.value" />

v-model是动态绑定值到value,而后监听input的inpit事件获取值后赋给dataA的一个过程。

在说一下input的value属性,在组件内部要定义一个value的props属性,以便可以动态绑定上父组件传过来的值;

组件内部还要作一件事情:

动态计算(获取和设置)currentValue的值,用到了vue的对象的get和set函数;

 

讲到这里,咱们就能够解决上面的问题了;

首先定义一个通用输入组件:

 

 1 Vue.component('my-component',{
 2     template:'<div><input type="text" type="text" v-model="currentValue"/></div>',
 3     data:function(){
 4         return {
 5             // 双向绑定值-必须
 6             currentValue:this.value
 7         }
 8     },
 9     props:['value'],// 设置value为props属性-必须
10     computed:{
11         currentValue: {
12             // 动态计算currentValue的值
13             get:function() {
14                 return this.value;
15             },
16             set:function(val) {
17                 this.$emit('input', val);
18             }
19         }
20     }
21 })

 

在Html里绑定到vue实例的一个字段上;

1 <div id="demo_01">
2     <my-component v-for="(val,key) in postData" v-model="postData[key]"></my-component>
3     <button @click="showValue">打印对象值</button>
4 </div>

实例里写一个方法

打印一下咱们绑定的值;

 1 var demo_01 = new Vue({
 2     el:'#demo_01',
 3     data:{
 4         postData:{
 5             name:'李雷',
 6             age:'80',
 7             describ:'这是一个传奇的人物'
 8         }
 9     },
10     methods:{
11         showValue:function(){
12             console.log(this.postData)
13         }
14     }
15 });

是否是之后就不用繁琐冗长的this.$children.xxx取值方式了?

结果【Result】:

提供了有效的解决了关于输入类组件取值方案,而且已经部署实施。

 

最后感谢你们阅读,欢迎你们提出问题探讨。

相关文章
相关标签/搜索