es6的Object.defineproperty
创始人
2025-05-28 19:17:47

1.(在f12控制台的字体颜色区别)

1.1未使用defineproperty添加属性



回顾Object.defineproperty方法



在这里插入图片描述

1.2 使用defineproperty添加属性

在这里插入图片描述

总结: 会发现,通过Object.defineproperty添加进来的属性颜色会浅些

2.是否可枚举

2.1未使用defineproperty添加属性



回顾Object.defineproperty方法



在这里插入图片描述

2.2 使用defineproperty添加属性



回顾Object.defineproperty方法



在这里插入图片描述

总结: Object.defineproperty不可枚举,就是不可以遍历得到通过Object.defineproperty添加进来的属性

3.使用enumerable



回顾Object.defineproperty方法



在这里插入图片描述

总结: 会发现添加了enumerable属性后,不仅可以枚举了,颜色也变深了。

但是会发现一个问题,就是无法修改



回顾Object.defineproperty方法



在这里插入图片描述

不是用Object.defineproperty的是可以修改的

在这里插入图片描述

4.使用writable

在这里插入图片描述

5.使用configurable

正常情况下,是可以任意删除属性的

在这里插入图片描述

使用Object.defineproperty的
在这里插入图片描述

添加configurable属性的
在这里插入图片描述

6.使用get函数

有个场景:如下代码,我想在控制台上让其number修改后,person.age也跟着改变



回顾Object.defineproperty方法



在这里插入图片描述

解决方案:使用Object.defineproperty里的get函数



回顾Object.defineproperty方法



在这里插入图片描述

会发现有个 get age:f() 刚好对应get函数对应的age属性

7.使用set函数



回顾Object.defineproperty方法



在这里插入图片描述

会发现person的age并没有发生变化,因为get函数会返回age的值,而get函数return的是number这个变量,如果需要修改,则在set函数中添加number=value;

在这里插入图片描述

在这里插入图片描述

相关内容

热门资讯

MiniMax上市后首份成绩单... 资料图。本文来源:第一财经 作者:刘晓洁MiniMax上市后首份成绩单:亏损与收入同增,海外份额超7...
格力电器回应“未来每年将不再派... 近日有投资者在互动平台向格力电器提问,称近期网络上有传闻称“格力电器未来每年将不再派发股息”,作为长...
年轻人的消费激情,在折扣店里生... 前段时间,一份权威调研报告,描绘了当下年轻人的消费画像:精打细算,“质价比”成为消费决策核心;为“心...
税务总局六项举措落地 规范招商... 3月2日,国家税务总局甩出重磅成果——2025年治理违规招商引资涉税问题的六项举措全面落地,直接剑指...
伊朗货币崩盘,2个月暴跌30倍... 记者丨冯紫彤编辑丨方海平 肖嘉 见习编辑林芊蔚汇率贬值超过30倍,伊朗仅用了两个月。21世纪经济报道...