vue 2.0组件与v-model详解
前言大家可能乍一看这个标题,可能会有疑问:v-model和组件也能扯到一起?在打算写这篇文章的时候,也是这么想的。咱们按简历的那一套STAR法则来梳理一下这篇文章: 情景【Situation】:编写通用的输入组件时,子组件要绑定到父组件的某个变量上dataA,当父组件要拿到自组件的值时不能通 而是父组件可以直接 任务【Task】:实现在父组件直接this.dataA就可以取到当前子组件最新值。 行动【Action】:首先要了解v-model这个指令,许多认真阅读过完整vue文档的同学可能已经知道了关于v-model。 v-model官方给出的说发是:这其实是一个简写的形式,v-model实际执行的是下面的绑定: v-model是动态绑定值到value,然后监听input的inpit事件获取值后赋给dataA的一个过程。 在说一下input的value属性,在组件内部要定义一个value的props属性,以便能够动态绑定上父组件传过来的值; 组件内部还要做一件事情: 动态计算(获取和设置)currentValue的值,用到了vue的对象的get和set函数; 讲到这里,我们就可以解决上面的问题了; 首先定义一个通用输入组件:',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);
}
}
}
})
在Html里绑定到vue实例的一个字段上; 实例里写一个方法打印一下我们绑定的值; 是不是以后就不用繁琐冗长的 结果【Result】: 提供了有效的解决了关于输入类组件取值方案,并且已经部署实施。 总结以上就是关于vue2.0 组件和v-model的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对编程之家的帮助。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |