vue2.0响应式原理

vue2.0响应式原理

vue2.x响应式原理(Object.defineProperty())

响应式原理的含义

就是利用object.defineproperty的getter和setter改变原有的逻辑,重写逻辑,对取值和设置进行观察操作

Object.defineProperty(obj,prop,descriptor)

Object->defineProperty :对象 ->定义 属性 。为对象添加一个属性,内容为descriptor

obj:对象

prop:属性

descriptor:描述项

//给对象添加一个属性
function defineProperty(){
var _obj = {}
Object.defineProperty(_obj,'a',{
  value:'纱萨婚纱'
})
return _obj
}
var obj = defineProperty()
console.log(obj)   // {a: "纱萨婚纱"}

//给对象添加多个属性
function defineProperty(){
var _obj = {}
Object.defineProperties(_obj,{
  a:{
      value:'抵押给'
  },
  b:{
      value:"事件的看法"
  }
})
return _obj
}
var obj = defineProperty()
console.log(obj)  //{a: "抵押给", b: "事件的看法"}

但是需要注意的是,经object.defineProperty操作过的对象,不可更改,不可枚举,不可删除。

但是也是有解决的办法的,他又这么几个属性:

writeable:true 可写入

enmuerable:true 可枚举 obejct.keys()/for …in…

configureable:true 可配置 就可以进行删除了

一道阿里面试题:

怎么能够进入到if中
if(a===1&a===2&a===3){
	console.log('you win!!!')
}
利用Object.defineProperty
var a=0
Object.defineProperty(window,'a',{
	get(){
		return ++a
	}
})

tips:未完待续。。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

_小郑有点困了

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值