05-数据代理
1.数据代理
学习数据代理需要 js 的一些知识:1Object.defineProperty()
,属性标志,属性描述符,getter,setter。。。
1.1数据代理
建议学习文章地址:
这里简单介绍一下:
属性标志:
对象属性(properties),除 value
外,还有三个特殊的特性(attributes),也就是所谓的“标志”
writable
— 如果为true
,则值可以被修改,否则它是只可读的enumerable
— 如果为true
,则表示是可以遍历的,可以在for.. .in
、Object.keys()
中遍历出来configurable
— 如果为true
,则此控制属性可以被删除,默认值是false
1 |
|
示例
1 |
|
1.2 vue 中的数据代理
数据代理:通过一个对象代理对另一个对象中属性的操作(读/写)
1 |
|
使用 插值语法获取
vm
的 x
时,触发 get
方法,返回 data
的 x
修改 data
中的 age
时并没有改变 vm
里的 age
的值,当 获取
vm
中 age
的值时,就会将 data
的 age
赋值给 vm
的 age
修改 vm
中的 age
触发 set
方法,将修改的值赋值给 data
中的 age
- Vue 中的数据代理通过 vm 对象来代理 data 对象中属性的操作(读/写)
- Vue 中数据代理的好处:更加方便的操作 data 中的数据
- 基本原理
- 通过
object.defineProperty()
把data
对象中所有属性添加到vm
上 - 为每一个添加到
vm
上的属性,都指定一个getter
,setter
- 在
getter
,setter
内部去操作(读/写)data中对应的属
- 通过
Vue
将 data
中的数据拷贝了一份到 _data
属性中,又将 _data
里面的属性提到 Vue实例
中(如name),通过 defineProperty
实现数据代理,这样通过 geter/setter
操作 name,进而操作 _data
中的 name
。而 _data
又对 data
进行数据劫持,实现响应式。
name被修改–>调用setter–>重新解析模板–>生成新的虚拟DOM–>新旧DOM对比(diff)–>更新页面
05-数据代理
https://flepeng.github.io/021-frontend-04-Vue-01-course-05-数据代理/