首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

js Object.defineProperty()详解

要修改属性的默认特性,就必须使用 Object.defineProperty()方法 ;在了解Object.defineProperty()之前,需要先明白对象属性的一些特性,明白了这些特性之后,对Object.defineProperty...Object.defineProperty() Object.defineProperty() 方法会直接在一个对象上定义一个新属性,或者修改一个对象的现有属性,并返回此对象; 语法: Object.defineProperty...Object.defineProperty设置数据属性 3.1 Configurable 注意: 如果该属性被定义为不可配置(false)之后,就不能再变回可配置的了,否则会报错。...const person = { name: 'lc', }; // 定义新属性 Object.defineProperty(person, "age", { configurable:...Object.defineProperty设置访问器属性 Configurable 和 Enumerable和上述一样,这里不再演示。 4.1 Get、Set get: 获取函数,在读取属性时调用。

2.3K20

使用 Object.defineProperty 为对象定义属性

Vue使用的是 ES5 提供的 Object.defineProperty() 结合发布者-订阅者模式,通过Object.defineProperty() 来劫持各个属性的setter,getter,在数据变动时发布消息给订阅者...Object.defineProperty() 定义以及使用 Object.defineProperty() 方法会直接在一个对象上定义一个新属性,或者修改一个已经存在的属性, 并返回这个对象。...Object.defineProperty 解决什么问题 如果你想定义一个对象的属性为只读怎么办? 「对象.属性」能做到吗?显然不能!Object.defineProperty 却可以做到。...因此 Object.defineProperty 方法是对属性更加精确的定义。...let o = Object.defineProperty({}, "a", {value: 1, enumerable: true}); Object.defineProperty(o, "b", {

87810

深入浅出Object.defineProperty()

本文部分参考了书籍《你不知道的javascript》上卷 对象的定义与赋值 经常使用的定义与赋值方法obj.prop =value或者obj['prop']=value Object.defineProperty...()语法说明 Object.defineProperty()的作用就是直接在一个对象上定义一个新属性,或者修改一个已经存在的属性 Object.defineProperty(obj, prop, desc...) obj 需要定义属性的当前对象 prop 当前需要定义的属性名 desc 属性描述符 一般通过为对象的属性赋值的情况下,对象的属性可以修改也可以删除,但是通过Object.defineProperty...虽然内部属性通常用一个双吕括号包围的名称来表示,但实际上这并不是它们的名字,它们是一种抽象操作,是不可见的,根本没有上面两种属性有的那种字符串类型的属性 属性描述符 通过Object.defineProperty...let Person = {}let temp = nullObject.defineProperty(Person, 'name', { get: function () { return temp

66240

【图解系列】Object.defineProperty vs Proxy

主题:【Object.defineProperty vs Proxy】 图解: 文字说明: Proxy Proxy 用于修改某些操作的默认行为,等同于在语言层面做出修改,所以属于一种“元编程”(meta...也就是传说中的新标准的性能红利; Object.defineProperty Object.defineProperty的优势如下: 兼容性好(支持IE9) Vue响应式实现,使用 Object.defineProperty...的缺点: Object.defineProperty (obj, prop, descriptor) 的问题主要有三个: 无法监听数组的变化 Vue 把会修改原来数组的方法定义为变异方法。...必须遍历对象的每个属性 使用 Object.defineProperty 多数情况下要配合 Object.keys 和遍历,于是就多了一层嵌套。...必须深层遍历嵌套的对象 当一个对象为深层嵌套的时候,必须进行逐层遍历,直到把每个对象的每个属性都调用 Object.defineProperty() 为止。

41710

Object.defineProperty也能监听数组变化?

本文简介 点赞 + 关注 + 收藏 = 学会了 首先,解答一下标题:Object.defineProperty 不能监听原生数组的变化。如需监听数组,要将数组转成对象。...在 Vue2 时是使用了 Object.defineProperty 监听数据变化,但我查了下 文档,发现 Object.defineProperty 是用来监听对象指定属性的变化。...基础用法 Object.defineProperty() 文档 关于 Object.defineProperty() 的用法,可以看官方文档。 基础部分本文只做简单的讲解。...语法 Object.defineProperty(obj, prop, descriptor) 参数 obj 要定义属性的对象。 prop 要定义或修改的属性的名称或 Symbol 。...以上就是 Object.defineProperty 的基础用法。 深度监听 上面的例子是监听基础的对象。但如果对象里还包含对象,这种情况就可以使用递归的方式。

43020

【javaScript】Proxy与Object.defineProperty的区别

@TOCProxy和Object.defineProperty都是JavaScript中用于实现对象属性拦截和代理的机制,但它们在功能和应用方面有一些区别。...功能方面的区别:Object.defineProperty:它是ES5引入的属性定义方法,通过直接定义对象属性的特性(如可枚举性、可写性等),可以拦截属性的读取、写入和删除操作。...比如:Object.defineProperty对整个对象进行赋值,不会触发set拦截const obj = {};Object.defineProperty(obj, 'name', { get()...对整个对象进行遍历,不会触发get拦截var obj = {};Object.defineProperty(obj, 'name', { get() { console.log('访问name属性...性能开销:相比Object.defineProperty,Proxy的拦截机制更为复杂,因此在某些情况下可能会引入一定的性能开销。但对于大多数应用场景来说,这种开销可以忽略不计。

14810
领券