vue计算属性与监视

2018-12-25  本文已影响0人  錦魚
// new 一个vue对象
const vm = new Vue({
    // 挂载节点块    对应节点
    el: '#demo',

    // 起始数据块(起始参数)  对应 v-modul
    data: {
        firstName: 'A',
        lastName: 'B',
        // fullName1: 'A B'
        fullName2: 'A B'
    },
    //
    // //计算属性 逻辑块
    computed: {
        // 什么时候执行:初始化显示/相关的data属性数据发生改变
        // 计算并返回当前属性的值
        // 方法
        fullName1(){//计算属性的一个方法,方法的返回值作为属性值
            console.log('fullName1()');//打印一个函数方法
            return this.firstName + ' ' + this.lastName ;//this是这个函数,值返回到fullName1  v-modle互相传递
        },
        //回调方法
        fullName3: {//赋值fullName3 的对调函数
            /*回调函数要满足3个条件:
                1、你定义的;
                2、你没有调用;
                3、但最终它执行了
            什么时候调用?
            用来做什么?              */

            // 回调函数,当需要读取当前属性值时回调,根据相关的数据计算并返回当前属性的值
            get(){return this.firstName + ' ' + this.lastName;},//返回拼合的结果,fullName3
            // 回调函数,监视当前属性值的变化,当属性值发生改变时回调,更新相关的属性数据
            set(value){// value就是fullName3的最新属性值 : 传递v-modle 的属性值,裁切后get返回
                const names = value.split(' ');
                this.firstName = names[0];
                this.lastName = names[1];// 给name 赋值
            }
        }
    },
    // // // 监听块逻辑
    // watch: {    //监听firstName
    //     //data.firstName发生了变化
    //  firstName: function(value){
    //      console.log(this); //就是VM对象
    //      this.fullName2 = value + ' ' + this.lastName;
    //  },
    //  lastName: function(value){
    //      console.log(this); //就是VM对象
    //      this.fullName2 = this.firstName + ' ' + value;
    //  }
    // }
});

// // vue外添加监听 lastName
vm.$watch('firstName', function(value){
    // 更新fullName2
    this.fullName2 = value + ' ' + this.lastName;
});
vm.$watch('lastName', function(value){
    // 更新fullName2
    this.fullName2 = this.firstName + ' ' + value;
});
上一篇 下一篇

猜你喜欢

热点阅读