当前位置: 首页 > news >正文

Vue核心基础1:数据代理

1 回顾Object.defineProperty方法

let str = 'hello'
const person = {name: '张三',age: 18
}

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}
})

console.log(person)
console.log(Object.keys(person))   // enumerable: true
person.sex = '女'  // writable: true
console.log(person)

2 何为数据代理

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

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

    <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); // 100obj2.x = 300console.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中对应的属性

http://www.lryc.cn/news/300127.html

相关文章:

  • 12 ABC串口接收原理与思路
  • leetcode(二分查找)34.在排序数组中查找元素的第一个和最后一个位置(C++详细解释)DAY11
  • 算法刷题框架
  • 跟着cherno手搓游戏引擎【24】开启2D引擎前的项目总结(包括前置知识汇总)
  • 石子合并+环形石子合并+能量项链+凸多边形的划分——区间DP
  • IMX6ULL移植U-Boot 2022.04
  • ES实战-高级聚合
  • 网络安全产品之认识蜜罐
  • 推荐《架构探险:从零开始写Java Web框架》
  • Go教程-Go语言简介
  • React + SpringBoot + Minio实现文件的预览
  • 心法利器[107] onnx和tensorRT的bert加速方案记录
  • AcWing 122 糖果传递(贪心)
  • unity的重中之重:组件
  • Linux释放内存
  • Python算法题集_翻转二叉树
  • Git快速掌握,通俗易懂
  • PHP毕业设计图片分享网站76t17
  • 代码随想录 Leetcode45. 跳跃游戏 II
  • 【C语言】socketpair 的系统调用
  • 【论文精读】BERT
  • Codeforces Round 925 (Div. 3) - A、B、C、D、E
  • 快速部署MES源码/万界星空科技开源MES
  • 【Python网络编程之TCP三次握手】
  • 【leetcode】深搜、暴搜、回溯、剪枝(C++)2
  • 鸿蒙开发-UI-图形-图片
  • .NET Core WebAPI中使用Log4net记录日志
  • Nginx配置php留档
  • 英语题不会怎么搜答案?分享五个支持答案和解析的工具 #学习方法#媒体
  • Rust 数据结构与算法:4栈:用栈实现进制转换