JavaScript 中 Object

一、Object 基本概念

JavaScript 的 Object 是存储键值对(属性和方法)的集合,所有对象(如 Array、Function 等)均继承自 Object.prototype
属性名可以是字符串或 Symbol,值可以是任何数据类型(包括其他对象或函数)

二、创建对象的方式

  1. 字面量创建‌(最常用):

let obj = { name: "John", age: 30 };

      构造函数创建‌:

let obj = new Object();obj.name = "John";

Object.create()‌(基于原型创建):

let parent = { type: "Parent" };let child = Object.create(parent); console.log(child.type); // "Parent" :ml-citation{ref="3,7" data="citationList"}

三、常用静态方法

方法作用示例
Object.assign()合并对象(浅拷贝)let newObj = Object.assign({}, obj1, obj2); 
Object.keys()返回对象自身可枚举属性名数组Object.keys({a:1, b:2}); // ["a", "b"] 
Object.values()返回对象自身可枚举属性值数组Object.values({a:1, b:2}); // [1, 2] 
Object.entries()返回键值对数组Object.entries({a:1}); // [["a",1]] 
Object.freeze()冻结对象(禁止增删改属性)Object.freeze(obj);

四、实例方法与特性

  1. 属性操作‌:

obj.prop = "value";        // 添加属性obj["prop"] = "value";     // 动态属性名delete obj.prop;           // 删除属性 :ml-citation{ref="7" data="citationList"}


‌     检测属性‌:

obj.hasOwnProperty("prop");    // 是否自身属性(非继承) :ml-citation{ref="8" data="citationList"}"prop" in obj;                 // 是否存在于原型链 :ml-citation{ref="8" data="citationList"}
  1. 原型链问题‌:

    • 所有对象默认继承 Object.prototype,可能导致原型污染(如通过 __proto__

    • 安全实践:避免直接操作 __proto__,使用 Object.create(null) 创建无原型对象。

五、遍历对象

  1. for...in 循环‌:遍历对象及其原型链的可枚举属性,需配合 hasOwnProperty 过滤:

for (const key in obj) {  if (obj.hasOwnProperty(key)) {    console.log(key, obj[key]);   }} :ml-citation{ref="1,7" data="citationList"}


      Object.keys() + forEach‌:仅遍历自身属性:

Object.keys(obj).forEach(key => {  console.log(key, obj[key]);}); :ml-citation{ref="7" data="citationList"}


六、注意事项

  1. 引用类型特性‌:
    Object 作为引用类型,赋值传递的是地址,修改会同步到所有引用该对象的变量

  2. 与 Map 的对比‌:

    • Object 的键只能是字符串或 Symbol,Map 支持任意类型键(如对象、函数)

    • Map 直接提供 size 属性和迭代方法,更适合频繁增删键值对的场景

// 创建对象const user = {  name: "Alice",  greet() {    console.log(`Hello, ${this.name}!`);  }};// 合并对象const details = { age: 25 };const merged = Object.assign({}, user, details); // {name: "Alice", age:25} :ml-citation{ref="1" data="citationList"}// 遍历属性Object.entries(merged).forEach(([key, val]) => {  console.log(`${key}: ${val}`); // "name: Alice", "age: 25"});



标签:

相关文章

夏天的台风

夏天,是一个充满活力和生命力的季节,但同时也伴随着台风的出现。每年的这个时期,台风如同一股强大的自然力量,给人们的生命和财产带来了一定的威胁。在台风的肆虐中,可以看到大自然的威力与无情。台风带来的强风...

工作总结报告怎么写

一、基础结构框架(六步法)‌引言开场‌用简明语言说明总结周期、岗位职责及整体工作成效。例如:“2025年在公司战略目标指导下,本人围绕XX职责,通过优化流程/创新方法等措施,顺利完成本年度KPI指标”...

前端对象-object

前端对象是JavaScript中用于表示数据和功能集合的核心概念,其设计遵循“万物皆对象”的抽象原则。以下从多个维度进行说明:一、对象定义与特征‌本质‌对象是由键值对构成的无序数据集合,键名与对应的值...

Vue3组合式API的核心

以下是Vue3组合式API的核心使用方法和实践要点:一、基础使用方式组件定义推荐使用defineComponent()函数定义组件,支持类型推断和setup识别<script setup>...

前端的最新消息2025707

🔥 一、框架与工具链革新‌Vite 取代 Webpack 成为主流构建工具‌Vite 6.5.0 新增 Marko 框架支持,集成 Redwood SDK,TypeScript 升级至 5.8 版,开...

需要前端技术的主要行业分类

前端开发作为连接用户与数字产品的桥梁,其应用场景已渗透到几乎所有数字化领域。以下是需要前端技术的主要行业分类及特点:‌互联网行业‌小程序开发(微信、支付宝等)成为新兴增长点,市场持续存在人才缺口‌传统...