vue 实例化几种方式_关于vue实例化属性的一些问题

烙印99

监听 data 变化的原理:/**  Observer是将输入的Plain Object进行处理,利用Object.defineProperty转化为getter与setter,  从而在赋值与取值时进行拦截  这是Vue响应式框架的基础 */function isObject(obj){    return obj != null && typeof(obj) == 'object';}function isPlainObject(obj){    return Object.prototype.toString(obj) == '[object Object]';}function observer(data){    if(!isObject(data) || !isPlainObject(data)){        return;    }    return new Observer(data);}var Observer = function(data){    this.data = data;    this.transform(data);};Observer.prototype.transform = function(data){    for(var key in data){        var value = data[key];        Object.defineProperty(data,key,{            enumerable:true,            configurable:true,            get:function(){                console.log("intercept get:"+key);                return value;            },            set:function(newVal){                console.log("intercept set:"+key);                if(newVal == value){                    return;                }                data[key] = newVal;            }        });        //递归处理        this.transform(value);    }};参考:理解 vue 实现原理

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值