【JavaScript】对象属性

JS 对象的可枚举性指的是对象的某些属性是否可以被 JSON.stringify()、 for...in 循环、Object.keys()、Object.values() 和 Object.entries() ⽅法枚举到。

每个对象属性都有⼀个名字和一个属性描述符,这个属性描述符⾥⾯包括了该属性的许多特性,如可枚举性、可写性、可配置性和值等。

默认情况下,使⽤字⾯量或Object()构造函数创建的对象的所有属性都是可枚举的,可以使⽤

Object.defineProperty或Object.defineProperties()来设置enumerable特性为false,设置其不

可枚举。

  • Object.defineProperty()作⽤:⽤来定义⼀个新的属性或者修改原有的属性
  • Object.defineProperties()作⽤:⽤来定义或修改多个属性

它们接收三个参数:1、obj对象;2、prop:要定义或修改的属性名称;3、descriptor:要定

义或修改的属性描述符 descriptor的属性描述符包括的特性有:

  1. value:属性的值,默认为undefined
  2. writable:属性是否可写,默认为false
  3. enumerable:属性是否可枚举,默认为false
  4. configurable:属性是否可配置,默认为false
  5. get:获取属性值的⽅法
  6. set:设置属性值的⽅法
js 复制代码
var o = { a: 1, b: 2 };
o.c = 3;
Object.defineProperty(o, "d", {
  value: 4,
  enumerable: false,
});
console.log(o.d); // 4
for (var key in o) { console.log(o[key]) };
// 1 2 3
console.log(Object.keys(o)); //['a','b','c']
console.log(JSON.stringify(o)); //"{a:1,b:2,c:3}"

⾄于 for...in 循环和 Object.keys ⽅法的区别,在于前者包括对象继承⾃原型对象的属性,⽽后者只包括对象本身的属性。有些内置对象的属性是不可枚举的,例如 Object.prototype 上的属性,这些属性可以通过 Object.getOwnPropertyNames() ⽅法获取。

相关推荐
小脑斧12320 分钟前
从范式重构到工程落地:OpenTiny NEXT 引领前端智能化新范式
前端·hermesagent·opentiny next
小江的记录本20 分钟前
【AI大模型选型指南】《2026年5月(最新版)国内外主流AI大模型选型指南》(企业版)
前端·人工智能·后端·ai作画·aigc·ai编程·ai写作
幽络源小助理26 分钟前
最新轻量美化表白墙系统源码v2.0_带后台版_附搭建教程
前端·开源·源码·php源码
qq_3813385038 分钟前
前端状态管理新范式:Zustand、Jotai 与 Preact Signals 深度对比
前端·arcgis
布局呆星40 分钟前
Vue Router 笔记(二):正则路由、组件通信与动态路由
前端·javascript·vue.js
晓杰'43 分钟前
Balatro后端进阶(1):自定义NestJS WebSocket Adapter实现消息拦截
后端·websocket·typescript·node.js·游戏开发·nestjs·wsadapter
丑八怪大丑1 小时前
HTML&CSS
前端·css·html
团象科技1 小时前
全渠道出海布局之下,多币种云结算承担着怎样的作用
前端·人工智能
rising start1 小时前
InsightEdu - 轻量智能学习平台
javascript·axios·css3·html5·fastapi·orm·dify
lolo大魔王1 小时前
Go 语言 Web 框架 Gin 入门详解
前端·golang·gin