zoukankan      html  css  js  c++  java
  • vue2.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实际执行的是下面的绑定:

    <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】:

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

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

  • 相关阅读:
    lambda续集——1
    c++之—— lambda表达式(有个未能解决的问题等待大佬解答)——(在stack overflow找到了答案)
    交换两个变量,只使用2个变量——权当面试了解使用
    移位实现正负数原码输出
    算法导论之——插入排序
    类模板的实现与定义相分离
    类模板
    当函数模板遇到普通函数
    c++之——template模板函数
    字符转数字,数字转字符
  • 原文地址:https://www.cnblogs.com/wwlhome/p/6551165.html
Copyright © 2011-2022 走看看