vue 2.0组件与v-model详解
前言
大家可能乍一看这个标题,可能会有疑问v-model和组件也能扯到一起?在打算写这篇文章的时候,也是这么想的。咱们按简历的那一套STAR法则来梳理一下这篇文章
情景【Situation】
编写通用的输入组件时,子组件要绑定到父组件的某个变量上dataA,当父组件要拿到自组件的值时不能通过this.$children.xxx
取值然后付给dataA,
而是父组件可以直接this.dataA
就可以取到当前子组件最新值。
任务【Task】
实现在父组件直接this.dataA就可以取到当前子组件最新值。
行动【Action】
要了解v-model这个指令,许多认真阅读过完整vue文档的同学可能已经知道了关于v-model。
v-model官方给出的说发是这其实是一个简写的形式,v-model实际执行的是狼蚁网站SEO优化的绑定
<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函数;
讲到这里,我们就可以解决上面的问题了;
定义一个通用输入组件
Vue.ponent('my-ponent',{ template:'<div><input type="text" type="text" v-model="currentValue"/></div>', data:function(){ return { // 双向绑定值-必须 currentValue:this.value } }, props:['value'],// 设置value为props属性-必须 puted:{ currentValue: { // 动态计算currentValue的值 get:function() { return this.value; }, set:function(val) { this.$emit('input', val); } } } })
在Html里绑定到vue实例的一个字段上;
<div id="demo_01"> <my-ponent v-for="(val,key) in postData" v-model="postData[key]"></my-ponent> <button @click="showValue">打印对象值</button> </div>
实例里写一个方法
打印一下我们绑定的值;
var demo_01 = new Vue({ el:'#demo_01', data:{ postData:{ name:'李雷', age:'80', describ:'这是一个传奇的人物' } }, methods:{ showValue:function(){ console.log(this.postData) } } });
是不是以后就不用繁琐冗长的this.$children.xxx
取值方式了?
结果【Result】
提供了有效的解决了关于输入类组件取值方案,并且已经部署实施。
以上就是关于vue2.0 组件和v-model的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对狼蚁SEO的帮助。
编程语言
- 宿迁百度关键词排名指南:实现精准营销的关键
- 四川SEO优化怎么做网络推广
- 立昂技术备案老域名收购:如何为您的业务赋能
- 安徽百度关键词seo贵不贵,一般需要多少钱
- 吉林百度快照排名怎么做电话营销
- 多伦新手做SEO怎么做
- 甘肃优化关键词排名推广怎么做论坛营销
- 沙雅SEO网站推广:提升您的在线可见性
- 四川SEO优化如何提升销售额和销售量
- 聂荣网站排名优化:提升网站可见性的全方位指
- 涞水SEO:提升地方企业在线可见性的策略
- 辽宁百度seo排名怎样做网站排名
- 临湘哪有关键词排名优化:提升网站可见度的关
- 黑龙江百度网站优化有没有优惠
- 凉城优化关键词排名推广:提升您的网络可见性
- 萝北整站优化:提升您网站流量和排名的全面指