浅谈JavaScript的defineProperty

2024-04-30 01:48

本文主要是介绍浅谈JavaScript的defineProperty,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Object.defineProperty定义新属性或修改原有的属性。

defineProperty

语法:

Object.defineProperty(obj, prop, descriptor)
参数说明:
obj:必需。目标对象
prop:必需。需定义或修改的属性的名字
descriptor:必需。目标属性所拥有的特性

四大特征

每个属性都有四大特征
value 实际存储属性值
writable 是否可以修改 默认是true
enumerable 是否可被for in遍历 仅仅只能控制 for in 无法控制访问
configurable 是否可修改其他属性特征 是否可删除该属性

获取变量的特性

Object.getOwnPropertyDescriptor(obj,prop’);
obj:必需。目标对象
prop:必需。需定义或修改的属性的名字

操作
var obj = {id : 1001,name : 'Eric',age : 10}
value

属性对应的值,可以使任意类型的值,默认为undefined
设置value属性

Object.defineProperty(obj,"name",{value:"hello"});console.log( obj.name );  //hello
writable

属性的值是否可以被重写。设置为true可以被重写;设置为false,不能被重写。默认为false。

第一种情况:writable设置为false,不能重写.严格模式下回报错

Object.defineProperty(obj,"name",{writable:false});
//更改name 的值
obj.name="change";
console.log( obj.name );  //Eric

第一种情况:writable设置为true,可以重写.

Object.defineProperty(obj,"name",{writable:true});obj.name="change";console.log( obj.name );  //change
enumerable

此属性是否可以被枚举(使用for…in或Object.keys())。设置为true可以被枚举;设置为false,不能被枚举。默认为false。

第一种情况:enumerable设置为false,不能被枚举。

Object.defineProperty(obj,"name",{enumerable:false
})
//枚举对象的属性
for( var key in obj ){console.log( key );  // id   age
}

第二种情况:enumerable设置为true,可以被枚举。

	Object.defineProperty(obj,"name",{enumerable:true});
//枚举对象的属性for( var key in obj ){console.log( key );   // id  name  age}
configurable

是否可以删除目标属性或是否可以再次修改属性的特性(writable, configurable, enumerable)。设置为true可以被删除或可以重新设置特性;设置为false,不能被可以被删除或不可以重新设置特性。默认为false。
这个属性起到两个作用:
目标属性是否可以使用delete删除
目标属性是否可以再次设置特性

  • 第一种作用:是否可以删除的作用
    第一种情况:configurable设置为false,不能被删除 严格模式下报错
Object.defineProperty(obj,"name",{configurable:false});//删除属性delete obj.name;console.log( obj );console.log( obj.name ); //Eric

第二种情况:configurable设置为true,可以被删除。

Object.defineProperty(obj,"name",{configurable:true});//删除属性delete obj.name;console.log( obj );console.log( obj.name ); //undefined
  • 第二种作用:是否可以再次修改特性
    第一种情况:configurable设置为false,不能再次修改特性。 报错
Object.defineProperty(obj,"name",{value:"hello",writable:false,enumerable:false,configurable:false
});//重新修改特性
Object.defineProperty(obj,"name",{value:"hello",writable:true,enumerable:true,configurable:true
});
console.log( obj.name); //报错:Uncaught TypeError: Cannot redefine property: newKey

第二种情况:configurable设置为true,可以再次修改特性。

Object.defineProperty(obj,"name",{value:"hello",writable:false,enumerable:false,configurable:true
});//重新修改特性
Object.defineProperty(obj,"name",{value:"hello",writable:true,enumerable:true,configurable:true
});
console.log( obj.name); //hello
批量设置属性的四大特征
    Object.defineProperties(jack,{id:{writable:false,configurable:false},name:{configurable:false},age:{enumerable:false,configurable:false}});

这篇关于浅谈JavaScript的defineProperty的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/947637

相关文章

Java利用@SneakyThrows注解提升异常处理效率详解

《Java利用@SneakyThrows注解提升异常处理效率详解》这篇文章将深度剖析@SneakyThrows的原理,用法,适用场景以及隐藏的陷阱,看看它如何让Java异常处理效率飙升50%,感兴趣的... 目录前言一、检查型异常的“诅咒”:为什么Java开发者讨厌它1.1 检查型异常的痛点1.2 为什么说

基于Java开发一个极简版敏感词检测工具

《基于Java开发一个极简版敏感词检测工具》这篇文章主要为大家详细介绍了如何基于Java开发一个极简版敏感词检测工具,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录你是否还在为敏感词检测头疼一、极简版Java敏感词检测工具的3大核心优势1.1 优势1:DFA算法驱动,效率提升10

Java使用正则提取字符串中的内容的详细步骤

《Java使用正则提取字符串中的内容的详细步骤》:本文主要介绍Java中使用正则表达式提取字符串内容的方法,通过Pattern和Matcher类实现,涵盖编译正则、查找匹配、分组捕获、数字与邮箱提... 目录1. 基础流程2. 关键方法说明3. 常见场景示例场景1:提取所有数字场景2:提取邮箱地址4. 高级

使用SpringBoot+InfluxDB实现高效数据存储与查询

《使用SpringBoot+InfluxDB实现高效数据存储与查询》InfluxDB是一个开源的时间序列数据库,特别适合处理带有时间戳的监控数据、指标数据等,下面详细介绍如何在SpringBoot项目... 目录1、项目介绍2、 InfluxDB 介绍3、Spring Boot 配置 InfluxDB4、I

基于Java和FFmpeg实现视频压缩和剪辑功能

《基于Java和FFmpeg实现视频压缩和剪辑功能》在视频处理开发中,压缩和剪辑是常见的需求,本文将介绍如何使用Java结合FFmpeg实现视频压缩和剪辑功能,同时去除数据库操作,仅专注于视频处理,需... 目录引言1. 环境准备1.1 项目依赖1.2 安装 FFmpeg2. 视频压缩功能实现2.1 主要功

使用Java读取本地文件并转换为MultipartFile对象的方法

《使用Java读取本地文件并转换为MultipartFile对象的方法》在许多JavaWeb应用中,我们经常会遇到将本地文件上传至服务器或其他系统的需求,在这种场景下,MultipartFile对象非... 目录1. 基本需求2. 自定义 MultipartFile 类3. 实现代码4. 代码解析5. 自定

Spring-DI依赖注入全过程

《Spring-DI依赖注入全过程》SpringDI是核心特性,通过容器管理依赖注入,降低耦合度,实现方式包括组件扫描、构造器/设值/字段注入、自动装配及作用域配置,支持灵活的依赖管理与生命周期控制,... 目录1. 什么是Spring DI?2.Spring如何做的DI3.总结1. 什么是Spring D

spring AMQP代码生成rabbitmq的exchange and queue教程

《springAMQP代码生成rabbitmq的exchangeandqueue教程》使用SpringAMQP代码直接创建RabbitMQexchange和queue,并确保绑定关系自动成立,简... 目录spring AMQP代码生成rabbitmq的exchange and 编程queue执行结果总结s

Java调用Python脚本实现HelloWorld的示例详解

《Java调用Python脚本实现HelloWorld的示例详解》作为程序员,我们经常会遇到需要在Java项目中调用Python脚本的场景,下面我们来看看如何从基础到进阶,一步步实现Java与Pyth... 目录一、环境准备二、基础调用:使用 Runtime.exec()2.1 实现步骤2.2 代码解析三、

聊聊springboot中如何自定义消息转换器

《聊聊springboot中如何自定义消息转换器》SpringBoot通过HttpMessageConverter处理HTTP数据转换,支持多种媒体类型,接下来通过本文给大家介绍springboot中... 目录核心接口springboot默认提供的转换器如何自定义消息转换器Spring Boot 中的消息