Vue核心基础1:数据代理

1 回顾Object.defineProperty方法

javascript 复制代码
let str = 'hello'
const person = {
     name: '张三',
     age: 18
}

javascript 复制代码
Object.defineProperty(person, 'sex', {
     // value: '男',
     // enumerable: true, // 控制属性是否可以枚举,默认值是false
     // writable: true, // 控制属性是否可以被修改,默认值是false
     // configurable: true, // 控制属性是否可以被删除, 默认为false

     // 当有人读取person的sex属性时,get函数就会被调用,且返回值就是sex的值
     // get: function () {
     //     return str
     // }
     get() {
          return str
     },
     set(value) {
          // 当有人修改person的sex属性时,set函数就会被调用,且会收到修改的具体值
          console.log('有人修改了sex属性,且值是', value)
          str = value
     }
})

javascript 复制代码
console.log(person)
console.log(Object.keys(person))   // enumerable: true
person.sex = '女'  // writable: true
console.log(person)

2 何为数据代理

通过一个对象代理对另一个对象中属性的操作(读/写)

以下代码就是通过obj2来代理obj :

javascript 复制代码
    <script>
        let obj = {
            x: 100
        }
        let obj2 = {
            y: 200
        }
        Object.defineProperty(obj2, 'x', {
            get() {
                return obj.x
            },
            set(value) {
                obj.x = value
            }
        })
        console.log(obj2.x); // 100
        obj2.x = 300
        console.log(obj.x); // 300
    </script>

3 Vue中的数据代理


总结:

  1. Vue中的数据代理:

通过vm对象来代理data中的属性的操作 (读/写)

2.Vue中数据代理的好处:

更加方便地操作data中地数据

3.基本原理:

通过Object.defineProperty()把data中所有属性添加到vm上,

为每一个添加到vm上的属性,都指定一个 getter和setter,

在getter/setter内部去操作data中对应的属性

相关推荐
之歆3 小时前
Composition API 深度解析 - 重新理解 Vue 的组件化编程
前端·javascript·vue.js
Cxiaomu3 小时前
React Native 双端一体工程,如何实现分端运行与分端打包?
javascript·react native·react.js
冰暮流星4 小时前
javascript之dom访问属性
开发语言·javascript·dubbo
一只小阿乐4 小时前
TypeScript中的React开发
前端·javascript·typescript·react
Highcharts.js4 小时前
Highcharts客户端导出使用文档说明|图表导出模块讲解
前端·javascript·pdf·highcharts·图表导出
华仔啊4 小时前
GitHub 25k Star!这款开源录屏工具,免费无水印可商用,彻底告别付费
javascript
一只小阿乐4 小时前
react路由中使用context
前端·javascript·react.js·context 上下文
Hilaku4 小时前
一周狂揽40K+ Star⭐ 的 Pretext 到底有多变态?
前端·javascript·html
前端郭德纲4 小时前
JavaScript 原型相关属性详解
开发语言·javascript·原型模式
533_4 小时前
适用于vue3的拖拽插件:vue-draggable-plus, vuedraggable@next
javascript·vue.js