1.vue2双向数据绑定实现
vue2主要借助于object.defineProperty实现(讲解)
data:image/s3,"s3://crabby-images/38513/38513be05f42417d832a3df696d6c103f4bd466f" alt=""
数据描述符:
1.configurable(默认false)值为true才能在该属性对应的对象上被删除
data:image/s3,"s3://crabby-images/40ad6/40ad6d68caf89fa66de876b9d56529d6489972bc" alt=""
data:image/s3,"s3://crabby-images/96f08/96f084411255ce6d53f83bef69fe58f880f9754d" alt=""
data:image/s3,"s3://crabby-images/0f347/0f347b7d3b947e798598bd27bcbb4873524960c2" alt=""
data:image/s3,"s3://crabby-images/22f11/22f11f7d3434908923b9052a153fe8e308718e4e" alt=""
2.enumerbale(默认值:false) 为true此属性可枚举
data:image/s3,"s3://crabby-images/9c6cc/9c6cc7d656531807af209f3713097cbe0d0c3171" alt=""
data:image/s3,"s3://crabby-images/14785/1478599ba17cef42ec5d8e8aeabe68876bda7da5" alt=""
data:image/s3,"s3://crabby-images/e8f90/e8f90eea8c2952c3261ef4602eec601e4c79f2ca" alt=""
data:image/s3,"s3://crabby-images/f171e/f171e7ac4ec1b7dc7c16580706ccd4b8df7863cd" alt=""
3.value:(默认值undefined)表示给该属性对应的值,可以是函数、对象、数值等。
data:image/s3,"s3://crabby-images/98194/98194d38cbe31e58f11672f38e8d776d96f643db" alt=""
data:image/s3,"s3://crabby-images/c5d7f/c5d7feea8e8be35037c2663248d4e8d0f912f811" alt=""
4. writable(默认值是false) 当值为true的时候,此属性才会被重新赋值。
data:image/s3,"s3://crabby-images/fd29b/fd29beb28b0c6bd9264abd8a9b04da1ce71285d7" alt=""
data:image/s3,"s3://crabby-images/6b226/6b2262dd5e2ada960a27acebf7f435a5a146beba" alt=""
存取描述符:
1.get(默认值undefined):当访问此属性就会调用该函数,执行时不需要传入任何参数,但会传入this对象(由于继承关系 this不一定是定义该属性的对象),该函数的返回值会被用作与属性的值。
data:image/s3,"s3://crabby-images/c8a44/c8a44c5b9332c1c058fc2ca15954864d1239f417" alt=""
data:image/s3,"s3://crabby-images/63930/6393029b352fb1992fdb6f753400d70dde9da309" alt=""
data:image/s3,"s3://crabby-images/f9105/f91057c57709492c1024842c50bd6f27c53aa68c" alt=""
data:image/s3,"s3://crabby-images/65a2d/65a2d97935fe91d295b7a91c46919188cb481525" alt=""
2.set(默认值:undefined):当属性值被修改会调用此函数,该方法接受一个参数(赋予的新值),会传入赋值时的this对象。
data:image/s3,"s3://crabby-images/f0a76/f0a765081863435199ce8c43fd8d9ed7eac9dd1e" alt=""
data:image/s3,"s3://crabby-images/5ae33/5ae33d8df54443aa817232b1cf6f5b6955521286" alt=""
Object.defineProperty缺点:
1.无法检测到对象属性的新增或删除
2.由于js的动态性,可以对对象追加新的属性或者删除其中的属性.这点对经过Object.defineProperty方法建立的响应式对象来说,只能追踪对象已有数据是否被修改,无法追踪新增属性和删除属性,需另外处理.
网友评论