理解Object.defineProperty()
理解Object.defineProperty()
Object.defineProperty() 方法直接在一个对象上定义一个新属性,或者修改一个已经存在的属性, 并返回这个对象。
基本语法:Object.defineProperty(obj, prop, descriptor)
@param obj 【必须】目标对象
@param prop【必须】新增或修改的属性名字
@param descriptor 属性描述符。
属性描述符 包括两种形式:数据描述符和存取描述符。数据描述符是一个拥有可写或不可写值的属性。存取描述符是由一对getter-setter函数功能来描述的属性。
但是该两者不能同时存在,描述符只能是其中之一。
一:数据描述符:
比如如下一个普通对象:
var obj = {
"name": "kongzhi"
};
数据描述符属性如下:
Object.defineProperty(obj, "name", {
configurable: true | false,
enumerable: true | false,
value: '任意类型的值',
writable: true | false
});
下面我们来理解下每个属性的含义:
1. value:
含义: 属性的值,可以是任何类型的值,默认为undefined
1-1 不设置value属性
如下代码:
var obj = {};
Object.defineProperty(obj, "name", {});
console.log(obj.name); // undefined
1-2 设置value属性
// 设置value 代码如下:
var obj = {};
Object.defineProperty(obj, "name", {
value: "kongzhi"
});
console.log(obj.name); // kongzhi
2. writable
含义:属性的值是否可以被重写,true: 可以被重写,false: 不能被重写。默认为false。
2-1 writable设置为false,不能重写,如下代码:
var obj = {};
Object.defineProperty(obj, "name", {
value: "kongzhi",
writable: false
});
// 先打印下值
console.log(obj.name); // kongzhi
// 更改值
obj.name = "longen";
// 再打印下
console.log(obj.name); // kongzhi
2-2 writable设置为true,可以被重写,如下代码:
var obj = {};
Object.defineProperty(obj, "name", {
value: "kongzhi",
writable: true
});
// 先打印下值
console.log(obj.name); // kongzhi
// 更改值
obj.name = "longen";
// 再打印下
console.log(obj.name); // longen
3. enumerable
含义:该属性是否可以被枚举(如:for..in 或 Object.keys()). 如果为true的话,可以被枚举,设置为false的话,不能被枚举,默认为false。
3-1 enumerable被设置为false,不能被枚举,如下代码:
var obj = {};
Object.defineProperty(obj, "name", {
value: "kongzhi",
writable: false,
enumerable: false
});
// 先打印对象一下看看
console.log(obj); // {name: "kongzhi"}
// 再枚举对象的属性
for(var attr in obj) {
console.log(attr); // 什么都没有输出 说明不能被枚举
}
3-2 enumerable 设置为true,可以被枚举,如下代码:
var obj = {};
Object.defineProperty(obj, "name", {
value: "kongzhi",
writable: false,
enumerable: true
});
// 先打印对象一下看看
console.log(obj); // {name: "kongzhi"}
// 再枚举对象的属性
for(var attr in obj) {
console.log(attr); // 输出 name
}
4. configurable
含义:是否可以删除目标属性或是否可以修改目标属性的特性。如果为true的话,可以被删除或可以修改属性,为false的话,不能删除目标属性或不能修改目标属性,默认为false
4-1 configurable: false, 为false的话,不能删除目标属性或不能修改目标属性。如下代码:
var obj = {};
Object.defineProperty(obj, "name", {
value: "kongzhi",
writable: false,
enumerable: false,
configurable: false
});
// 先打印对象一下看看
console.log(obj); // {name: "kongzhi"}
// 删除属性
delete obj.name;
// 重新打印下对象,看是否删除成功了
console.log(obj.name); // kongzhi
// 修改属性
obj.name = "longen";
// 重新打印下对象,看是否修改成功了
console.log(obj.name); // kongzhi
4-2 configurable: true, 可以删除目标属性 或 可以修改目标属性,如下代码:
var obj = {};
Object.defineProperty(obj, "name", {
value: "kongzhi",
writable: false,
enumerable: false,
configurable: true
});
// 先打印对象一下看看
console.log(obj); // {name: "kongzhi"}
// 删除属性
delete obj.name;
// 重新打印下对象,看是否删除成功了
console.log(obj.name); // undefined
// 修改属性
obj.name = "longen";
// 重新打印下对象,看是否修改成功了
console.log(obj.name); // longen
二: 存取器描述
使用存取器描述属性的时候,可以使用如下属性:
var obj = {};
Object.defineProperty(obj, "name", {
enumerable: true | false,
configurable: true | false,
get: function() {} | undefined,
set: function(value) {} | undefined
});
注意:当使用了getter或setter的时候,就不能使用writable和value这两个属性。否则会报错。
getter 是获取属性值的方法。如果没有getter 则默认为 undefined,当我们读取某个属性的时候,其实是在对象内部调用了该方法,该方法必须使用return语句,返回值被作为属性值。
setter 是设置属性的方法。如果没有setter,则默认为undefined,该方法接收一个参数,并将该参数值分配该属性。当我们设置某个属性的时候,实际上在对象的内部调用了该方法。
如下代码是使用getter和setter的代码:
var obj = {};
var initValue = "kongzhi";
Object.defineProperty(obj, "name", {
get: function() {
// 当获取属性值的时候触发的函数
return initValue;
} ,
set: function(value) {
// 当设置值的时候触发的函数
initValue = value;
}
});
// 获取值
console.log(obj.name); // kongzhi
// 设置值
obj.name = "longen";
// 打印下
console.log(obj.name); // longen
理解Object.defineProperty()的更多相关文章
- 深入理解 Object.defineProperty 及实现数据双向绑定
Object.defineProperty() 和 Proxy 对象,都可以用来对数据的劫持操作.何为数据劫持呢?就是在我们访问或者修改某个对象的某个属性的时候,通过一段代码进行拦截行为,然后进行额外 ...
- 理解 Object.defineProperty
理解 Object.defineProperty 本文写于 2020 年 10 月 13 日 Object.defineProperty 用于在一个对象上定义新的属性或修改现有属性并返回该对象. 什么 ...
- 理解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:要修改或者添加的属性名称 ...
随机推荐
- [转载] Mahout
转载自http://hadoop.readthedocs.org/en/latest/Hadoop-Mahout.html# Mahout 12.1 简介 Mahout为推荐引擎提供了一些可扩展的机器 ...
- python3学习笔记(0)
一.编程语言主要从以下几个角度分类:1.编译型和解释型2.静态语言和动态语言3.强类型定义语言和弱类型定义语言编译型:程序运行前先由负责翻译的程序将代码转换成可执行代码进行执行.例如C/C++.Pas ...
- 企业级应用TOMCAT
第1章 Tomcat 1.1 Tomcat简介 Tomcat是一个免开放源代码的Web应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不多的场合下被普遍使用,是开发调试JSP程序的首选,另 ...
- Redis 高可用集群
Redis 高可用集群 Redis 的集群主从模型是一种高可用的集群架构.本章主要内容有:高可用集群的搭建,Jedis连接集群,新增集群节点,删除集群节点,其他配置补充说明. 高可用集群搭建 集群(c ...
- 01.redis初识
Redis学习: redis是什么? Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库.缓存和消息中间件. 不过Redis在生产环境中使用最多的功能是缓存系统.至于其 ...
- springboot整合rabbitmq
概述 RabbitMQ是一个开源的消息代理和队列服务器,用来通过普通协议在完全不同的应用之间共享数据,或者简单地将作业队列以便让分布式服务器进行处理. 它现实了AMQP协议,并且遵循Mozilla P ...
- POJ3624--01背包
Charm Bracelet Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 34013 Accepted: 15087 ...
- form表单提交引发的血案
最近,公司某条产品线上的一个功能出了问题:点击查询的时候,该页面在IE上直接卡死,chrome上会卡顿一段时间候提交表单进行查询.拿到这个bug单子以后,简单重现了下,基本上定位到是查询操作中的问题, ...
- python学习之路day2
模块学习: 标准库: os: 第三方库:
- 【NOIP2016提高组】愤怒的小鸟
https://www.luogu.org/problem/show?pid=2831 BFS 看到N这么小就可以想到搜索,求最少步数显然应该用BFS. 在这题中过两猪可以唯一确定一条抛物线,每一步可 ...