vue 2.0组件与v

网友投稿 186 2023-05-30


vue 2.0组件与v

前言

大家可能乍一看这个标题,可能会有疑问:v-model和组件也能扯到一起?在打算写这篇文章的时候,也是这么想的。咱们按简历的那一套STAR法则来梳理一下这篇文章:

情景【Situation】:

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

而是父组件可以直接this.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函数;

讲到这里,我们就可以解决上面的问题了;

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

Vue.component('my-component',{

template:'

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实例的一个字段上;

</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的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对我们的帮助。


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Java实现单链表翻转实例代码
下一篇:使用Post方法模拟登陆爬取网页的实现方法
相关文章

 发表评论

暂时没有评论,来抢沙发吧~