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

Object.defineProperty和响应式

Object.defineProperty()是一个监听对象属性变化的方法。一般情况下我们是不会直接使用的,或者说我们遇到的场景还没有这么高级。

最有名的例子就是Vue2的响应式实现,就是通过这个方法来实现的。

用起来不难,就是个API,只是用的比较少或者实现的功能都看起来很吊的样子,所以显得很高级。其实也就那样。

定义

Object.defineProperty() 静态方法会直接在一个对象上定义一个新属性,或修改其现有属性,并返回此对象。

定义新属性

运行下面的代码可以观察输出。

const obj1={}
Object.defineProperty(obj1,"property1",{value:1
})
console.log(obj1)//输出{}
console.log(obj1.property1)//输出1

obj1.property1输出1,这是符合我们的预期的。但obj1却输出{},我们期待的应该是{property1:1}。这就非常的奇怪了。明明obj1.property1可以输出property1的值,但输出obj1对象的时候却是空对象。

这就是Object.defineProperty()高级的一个地方。实际上,我们可以通过enumerable这个选项来控制属性是否对用户可见。

const obj1={}
Object.defineProperty(obj1,"property1",{value:1,enumerable:true
})
console.log(obj1)//输出{property1:1}
console.log(obj1.property1)//输出1

修改后,obj1的输出值就是{property1:1}。实际上我们利用defineProperty控制了属性的可见性。一般都会让用户可见。

数据描述符和访问器描述符

数据描述符指的是value和writable属性。访问器描述符指的get和set函数。两者是互斥的。

数据描述符

value的值就是属性的值。是可以读写的通过writable来控制的。

const obj1={}
Object.defineProperty(obj1,"property1",{value:1,writable:true,
})
obj1.property1=10
console.log(obj1.property1)//writable为false的时候,输出1,writable为true的时候,输出10,

writable为false的时候,obj1.property1=10并不会成功赋值。obj1.property1的值还是输出1,并不会报错。writable为true的时候,输出10,赋值成功。

访问器描述符

访问描述符是另一套读写数据的方式。不能够在get和set方法里面调用value,因为数据描述符和访问器描述符是互斥的。

const obj1 = {}
let property1Value = 1//必须自己定义一个变量来设置属性值
Object.defineProperty(obj1, "property1", {enumerable: true,get() {console.log("get:")return property1Value},set(newValue) {property1Value = newValue}
})
property1Value = 10
console.log(obj1)//输出{ property1: [Getter/Setter] }
console.log(obj1.property1)//输出10

在enumerable: true的情况下,obj1输出{ property1: [Getter/Setter] },就是长这样。enumerable: false的情况下,输出{}。

数据描述符和访问器描述符的主要区别

两者都是可以获取和修改属性值的。主要区别就是能不能监听到值的获取或者改变,也就是被Vue等控件玩出花的所谓响应式

1.不需要监听值的改变用数据描述符就行了,自带value值,没什么操作性。
2.需要监听值的改变就要用访问器描述符了。需要自己定义属性值的变量。读取的逻辑都需要自己实现,更灵活也更加强大复杂。

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

相关文章:

  • 前端web
  • DDNet 服务器配置教程 Linux 环境
  • Vue 2 —监视器实现动态切换表单属性值
  • Qt_day10_程序打包(完结)
  • golang通用后台管理系统09(系统操作日志记录)
  • 如何确保爬取的数据准确性和完整性?
  • 【java】JDK安装
  • 科技改变工作方式:群晖NAS安装内网穿透实现个性化办公office文档分享(1)
  • 基于Java Springboot甘肃旅游管理系统
  • 03-axios常用的请求方法、axios错误处理
  • 《天体》游戏配置要求介绍
  • 【企业级分布式系统】 Kafka集群
  • MySQL 中有哪几种锁?
  • kafka中节点如何服役和退役
  • HTML5实现剪刀石头布小游戏(附源码)
  • 集群聊天服务器(3)muduo网络库
  • 解决在Ubuntu 20.04中使用PyCharm时无法输入中文的问题
  • 【jvm】HotSpot中方法区的演进
  • Win10/11 安装使用 Neo4j Community Edition
  • Ubuntu 22.04 上快速搭建 Samba 文件共享服务器
  • JQuery 基础知识学习(详尽版)2024.11.17
  • Spring Validation参数校验
  • 高斯数据库Postgresql死锁和锁表解决方法
  • 【设计模式】模板方法模式 在java中的应用
  • PVE纵览-安装系统卡“Loading Driver”的快速解决方案
  • Lua资料
  • 【C语言】值传递和地址传递
  • PyTorch 中使用自动求导计算梯度
  • Oracle Instant Client 23.5安装配置完整教程
  • 【jvm】方法区的理解