vue2.0 组件和v-model
2017-03-15 21:02
495 查看
本文适合初学组件编写的同学阅读。
乍一看这个标题,可能会有疑问:v-model和组件也能扯到一起?
我打算写这篇文章的时候,也是这么想的。咱们按简历的那一套STAR法则来梳理一下这篇文章:
情景【Situation】:
编写通用的输入组件时,子组件要绑定到父组件的某个变量上dataA,当父组件要拿到自组件的值时不能通过this.$children.xxx取值然后付给dataA,
而是父组件可以直接this.dataA就可以取到当前子组件最新值。
任务【Task】:
实现在父组件直接this.dataA就可以取到当前子组件最新值。
行动【Action】:
首先要了解v-model这个指令,许多认真阅读过完整vue文档的同学可能已经知道了关于v-model。
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函数;
讲到这里,我们就可以解决上面的问题了;
首先定义一个通用输入组件:
在Html里绑定到vue实例的一个字段上;
实例里写一个方法
打印一下我们绑定的值;
是不是以后就不用繁琐冗长的this.$children.xxx取值方式了?
结果【Result】:
提供了有效的解决了关于输入类组件取值方案,并且已经部署实施。
最后感谢大家阅读,欢迎大家提出问题探讨。
乍一看这个标题,可能会有疑问:v-model和组件也能扯到一起?
我打算写这篇文章的时候,也是这么想的。咱们按简历的那一套STAR法则来梳理一下这篇文章:
情景【Situation】:
编写通用的输入组件时,子组件要绑定到父组件的某个变量上dataA,当父组件要拿到自组件的值时不能通过this.$children.xxx取值然后付给dataA,
而是父组件可以直接this.dataA就可以取到当前子组件最新值。
任务【Task】:
实现在父组件直接this.dataA就可以取到当前子组件最新值。
行动【Action】:
首先要了解v-model这个指令,许多认真阅读过完整vue文档的同学可能已经知道了关于v-model。
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】:
提供了有效的解决了关于输入类组件取值方案,并且已经部署实施。
最后感谢大家阅读,欢迎大家提出问题探讨。
相关文章推荐
- VUE2.0增删改查附编辑添加model(弹框)组件共用
- vue 2.0组件与v-model详解
- vue 2.0封装model组件的方法
- Vue2.0利用 v-model 实现组件props双向绑定的优美解决方案
- VUE2.0增删改查附编辑添加model(弹框)组件共用
- [置顶] VUE2.0增删改查附编辑添加model(弹框)组件共用
- Vue 2.0学习笔记:组件数据传递
- 基于Vue2.0的分页组件
- 基于Vue 2.0的模块化前端 UI 组件库小结
- vue日期组件,支持vue1.0和2.0
- vue.js 2.0父子组件学习入门套路
- Vue 2.0 制作列表组件,实现分页、搜索、批量操作等
- Vue2.0 进阶组件篇 3 值得一看的(Toast 组件)
- vue2.0 仿手机新闻站(五)全局的 loading 组件
- vue2.0组件入门
- vue-router2.0 组件之间传参及获取动态参数
- vue2.0+SVG实现音乐播放圆形进度条组件,传入实时百分比实现圆圈进度动画效果
- Vue2.0的通用组件
- vue2.0父子组件以及非父子组件如何通信
- vue2.0父子组件以及非父子组件如何通信