理解 Object.defineProperty
理解 Object.defineProperty
本文写于 2020 年 10 月 13 日
Object.defineProperty 用于在一个对象上定义新的属性或修改现有属性并返回该对象。
什么意思呢?先不慌着理解,来一个例子看看再说。
const obj1 = {};
Object.defineProperty(obj1, 'property1', {
value: 42,
writable: false,
});
obj1.property1 = 77;
console.log(obj1.property1); // 42
上过小学二年的同学都能看懂这段英文,说的是
- 我们在
obj1
上定义一个 property(可以理解是一个属性或者元素); - 这个 property 的名字叫做
property1
; property1
的值为42
;- 她不可以被改写。
因此我们访问 obj1
这个空对象的 property1
属性可以得到结果,但是一旦我们想要修改对应的值,会发现修改失败。
语法
Object.defineProperty(obj, prop, descriptor);
obj
要操作的对象,也就是 target。
prop
要新增或者修改的属性名称(可以是 Symbol)。
descriptor
一个对象,用于描述你的新增或是修改。
具体属性如下:
interface Descriptor {
configurable?: boolean;
enumerable?: boolean;
value?: any;
writable?: boolean;
get?: () => any;
set?: (value: any) => void;
}
上面使用了一下 TS 的接口写法,不理解的同学可以看一下文档。
总的来说,如果我们简单的使用 const obj = { a: 1 };
来定义对象的属性,那么该属性是可以修改或做出其他很多操作的;但如果使用 Object.defineProperty()
,在不添加 descriptor
属性的前提下,该属性就是immutable(不可修改)的。
Descriptor
descriptor 拥有 6 个属性,可以分为两大类:数据描述符和存取描述符。
很容易猜到,get
与 set
就是存取描述符,其他的 4 个都是数据描述符。
让我们逐一击破。
configurable
顾名思义,指的是该属性是否可以进行配置,也就是说只有该选项为 true
,属性值才能被改变或者删除。
该属性默认为 false
。
enumerable
该属性译为「数不清的」,因此我们能猜到,该属性和枚举相关。
当它为 true
时,该属性才会出现在对象的枚举属性中。
默认为 false
。
value
不多解释,可以为任何有效的 JavaScript 数据,是该属性对应的值。
默认为 undefined
。
writable
描述该属性是否可以修改,与 configurable
不同的在于,即使 writable
设置为 false
,该属性也可以做出删除或其他修改以外的操作。该选项只对赋值运算符起作用。
默认为 false
。
get
配置了该属性的 getter
函数。每当我们访问这个属性,就会调用 get。比如 console.log(obj.a)
。该函数配置的返回值就将会是访问获得的值。
该函数不接受任何参数,但是存在 this
对象(但是不确定会指向谁)。
默认值为 undefined
。
set
配置该函数的 setter
函数。当属性值被修改时,就会调用该函数。
函数接收一个参数,该参数就是即将修改的新值。同样,该函数也存在 this
。
默认值为 undefined
。
(完)
理解 Object.defineProperty的更多相关文章
- 理解Object.defineProperty()
理解Object.defineProperty() Object.defineProperty() 方法直接在一个对象上定义一个新属性,或者修改一个已经存在的属性, 并返回这个对象. 基本语法:Obj ...
- 深入理解 Object.defineProperty 及实现数据双向绑定
Object.defineProperty() 和 Proxy 对象,都可以用来对数据的劫持操作.何为数据劫持呢?就是在我们访问或者修改某个对象的某个属性的时候,通过一段代码进行拦截行为,然后进行额外 ...
- 理解Object.defineProperty函数中的get与set
defineProperty是什么: 该函数可以直接在一个对象上定义一个新属性,或者修改一个对象的现有属性, 并返回这个对象.通俗理解就是: 给对象添加一个新的属性,或者针对对象里的某些属性,可以给这 ...
- 理解Object.defineProperty的作用
对象是由多个名/值对组成的无序的集合.对象中每个属性对应任意类型的值.定义对象可以使用构造函数或字面量的形式: var obj = new Object; //obj = {} obj.name = ...
- [转] 理解Object.defineProperty的作用
对象是由多个名/值对组成的无序的集合.对象中每个属性对应任意类型的值.定义对象可以使用构造函数或字面量的形式: var obj = new Object; //obj = {} obj.name = ...
- 《转》理解Object.defineProperty的作用
对象是由多个名/值对组成的无序的集合.对象中每个属性对应任意类型的值.定义对象可以使用构造函数或字面量的形式: var obj = new Object; //obj = {} obj.name = ...
- 简单的理解 Object.defineProperty()
Object.defineProperty()的作用就是直接在一个对象上定义一个新属性,或者修改一个已经存在的属性. Object.defineProperty(obj,prop,descriptor ...
- vue之Object.defineProperty()
了解Object.defineProerty()方法 关于Object.defineProperty()方法的解释,理解Object.defineProperty的作用 这篇文章做了很详细的概述 关于 ...
- 浅谈兔兔对Object.defineProperty的理解
给一个对象定义一个新的属性或者在修改一个对象现有的属性,并返回这个对象 语法: Object.defineProperty(参数1,参数2,参数3) 参数1:目标对象 参数2:要修改或者添加的属性名称 ...
随机推荐
- redis 使用详解
前戏: 又到了最喜欢的前戏部分,这个前戏可能有点长: Nosql和sql的区别 存储结构与mysql这一种关系型数据库完全不同,nosql存储的是KV形式 应用场景不同,sql支持关系复杂的数据查询, ...
- 实验配置cisco单臂路由
第一步 搭建实验拓扑图 第二步 对路由器做基本配置 为路由器创建名称: 设置进入特权模式 口令:控制台登录密码:vty登录密码 禁用DNS查找: 加密明文密码: 创建一个向访问设备者发出警告的标语&q ...
- python学习笔记(十)——进程间通信
python 在进程间通信时有很多方式,比如使用Queue的消息队列,使用 pip的管道通信,share memory 共享内存或 semaphore 信号量等通信方式. 这里我们演示一下通过消息队列 ...
- 知网上的硕士和博士论文怎么下载pdf格式
文献管理使用的EndNote,阅读习惯使用Drawboard,在下载硕士和博士论文时在知网上只能下载caj格式,于是就想找一种能下载pdf的方式. 知乎中有篇文章介绍的如何下载pdf的方法,很管用也很 ...
- centos下用ffmpeg推流宇视科技摄像头rtsp流到前端播放(无flash)
严禁垃圾中文技术网站复制粘贴 流程:安装SRS服务接收ffmpeg的推流,SRS会提供一个flv的播放地址,前端通过fls.js播放即可,无需flash. 1.安装ffmpeg 提供两个版本,都能推流 ...
- html5中常被忘记的标签,属性
placeholder placeholder是input中的属性,就是默认输入的text,当用户输入时,text会被清空. 用法 <input type ="text" p ...
- 【Web Audio API】 — 那些年的 web audio
转 TAT.Jdo:[Web Audio API] - 那些年的 web audio 这主题主要是早期对 web audio api的一些尝试,这里整理一下以便以后翻阅,如有错误,诚请指正. 在这之前 ...
- Web 开发中 Blob 与 FileAPI 使用简述
本文节选自 Awesome CheatSheet/DOM CheatSheet,主要是对 DOM 操作中常见的 Blob.File API 相关概念进行简要描述. Web 开发中 Blob 与 Fil ...
- LC-209
给定一个含有 n 个正整数的数组和一个正整数 target . 找出该数组中满足其和 ≥ target 的长度最小的 连续子数组 [numsl, numsl+1, ..., numsr-1, nums ...
- LC-844
给定 s 和 t 两个字符串,当它们分别被输入到空白的文本编辑器后,如果两者相等,返回 true .# 代表退格字符. 注意:如果对空文本输入退格字符,文本继续为空. 示例 1: 输入:s = &qu ...