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中对应的属性

相关推荐
周小码6 小时前
CesiumJS详解:打造专业级Web 3D地球仪与地图的JavaScript库
前端·javascript·3d
哆啦A梦15886 小时前
Element-Plus
前端·vue.js·ts
前端小巷子6 小时前
JS 打造丝滑手风琴
前端·javascript·面试
Mintopia6 小时前
多模态 AIGC 在 Web 内容创作中的技术融合实践:把“创作引擎”装进浏览器
前端·javascript·aigc
Mintopia7 小时前
Next.js 的 Web Vitals 监测与 Lighthouse 分析:从底层到实战的快乐科学
前端·javascript·next.js
一枚前端小能手7 小时前
「周更第2期」实用JS库推荐:Rsbuild
前端·javascript
小桥风满袖7 小时前
极简三分钟ES6 - 正则表达式的扩展
前端·javascript
柯南二号7 小时前
【大前端】React 使用 Redux 实现组件通信的 Demo 示例
前端·javascript·react.js
小高0077 小时前
🚨 2025 最该淘汰的 10 个前端 API!
前端·javascript·面试
一枚前端小能手7 小时前
🎨 页面卡得像PPT?浏览器渲染原理告诉你性能瓶颈在哪
前端·javascript