0

0

javascript对象如何创建与访问_怎样使用展开运算符和结构赋值【教程】

狼影

狼影

发布时间:2026-02-02 20:13:02

|

455人浏览过

|

来源于php中文网

原创

对象创建有字面量、new Object()、构造函数/类三种方式:字面量最常用,适合静态结构;new Object()语义弱少用;构造函数或类适合复用、带方法或初始化逻辑的对象。

javascript对象如何创建与访问_怎样使用展开运算符和结构赋值【教程】

对象创建的三种常用方式及其适用场景

直接字面量最常用,适合静态结构;new Object()基本不用,语义弱且冗长;构造函数或类适合需要复用、带方法或初始化逻辑的对象。比如定义用户数据,{ name: "Alice", age: 30 }足够;但要做多次实例化并带getName()方法,就该用class User

  • 字面量中属性名含空格或特殊字符时,必须用引号包裹:{"full name": "Bob"},访问时只能用方括号:obj["full name"]
  • 构造函数内避免漏写this.,否则属性会意外挂到全局(非严格模式下)
  • Object.create(null)创建无原型的对象,适合做纯哈希表,但不能用hasOwnProperty等继承方法

点号和方括号访问的本质区别

点号.要求属性名是合法标识符且编译期已知;方括号[]支持动态计算、变量、表达式和非法标识符。两者在运行时行为一致,但语法约束不同。

  • obj.name 等价于 obj["name"],但 obj.user name 会报错,必须写成 obj["user name"]
  • 当属性名来自变量时,只能用方括号:const key = "age"; obj[key]
  • 访问嵌套属性时,obj?.address?.city(可选链)比 obj && obj.address && obj.address.city 更安全,尤其处理 API 返回的不确定结构

展开运算符...在对象中的实际限制

对象展开只做一层浅拷贝,不递归;不能展开nullundefined;多个同名属性时,后面覆盖前面;不能直接展开在表达式中间(如{ ...a, b: 1, ...c }合法,但{ ...a, ...b + 1 }非法)。

  • 浅拷贝意味着:const a = { x: { y: 1 } }; const b = { ...a }; b.x.y = 2会同时改掉a.x.y
  • 合并配置时常见写法:const config = { ...defaultConfig, ...userConfig },注意userConfig优先级更高
  • 想深拷贝?别依赖展开,改用structuredClone()(现代环境)或JSON.parse(JSON.stringify(obj))(仅限纯数据)

解构赋值中默认值、重命名与嵌套的易错点

解构本质是模式匹配,不是简单赋值。默认值只在对应属性为undefined时生效,nullfalse0都会被原样取用;重命名用oldName: newName语法;嵌套解构需严格对齐结构。

Midjourney
Midjourney

当前最火的AI绘图生成工具,可以根据文本提示生成华丽的视觉图片。

下载

立即学习Java免费学习笔记(深入)”;

  • const { name = "Anonymous", age } = { name: null, age: 25 }namenull,不是"Anonymous"
  • 重命名同时设默认值:const { title: bookTitle = "Untitled" } = {}
  • 嵌套解构失败不报错,而是赋值为undefinedconst { user: { name } } = { }nameundefined,不是ReferenceError
  • 函数参数解构常被忽略默认值作用域function f({ x = 1 } = {}) { return x; },调用f()才触发默认值,f({})xundefined

对象操作看着简单,但展开和解构的“浅”特性、默认值的触发条件、属性访问的动态性,这几处最容易在真实项目里埋下隐性 bug。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

424

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

537

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

313

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

78

2025.09.10

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

238

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

499

2024.03.01

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1505

2023.10.24

Go语言中的运算符有哪些
Go语言中的运算符有哪些

Go语言中的运算符有:1、加法运算符;2、减法运算符;3、乘法运算符;4、除法运算符;5、取余运算符;6、比较运算符;7、位运算符;8、按位与运算符;9、按位或运算符;10、按位异或运算符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

233

2024.02.23

AO3官网入口与中文阅读设置 AO3网页版使用与访问
AO3官网入口与中文阅读设置 AO3网页版使用与访问

本专题围绕 Archive of Our Own(AO3)官网入口展开,系统整理 AO3 最新可用官网地址、网页版访问方式、正确打开链接的方法,并详细讲解 AO3 中文界面设置、阅读语言切换及基础使用流程,帮助用户稳定访问 AO3 官网,高效完成中文阅读与作品浏览。

89

2026.02.02

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 4.5万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.6万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号