javascript对象如何创建与访问_怎样使用展开运算符和结构赋值【教程】
发布时间 - 2026-02-02 00:00:00 点击率:次对象创建有字面量、new Object()、构造函数/类三种方式:字面量最常用,适合静态结构;new Object()语义弱少用;构造函数或类适合复用、带方法或初始化逻辑的对象。
对象创建的三种常用方式及其适用场景
直接字面量最常用,适合静态结构;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 返回的不确定结构
展开运算符...在对象中的实际限制
对象展开只做一层浅拷贝,不递归;不能展开null或undefined;多个同名属性时,后面覆盖前面;不能直接展开在表达式中间(如{ ...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时生效,null、false、0都会被原样取用;重命名用oldName: newName语法;嵌套解构需严格对齐结构。
-
const { name = "Anonymous", age } = { name: null, age: 25 }→name是null,不是"Anonymous" - 重命名同时设默认值:
const { title: bookTitle = "Untitled" } = {} - 嵌套解构失败不报错,而是赋值为
undefined:const { user: { name } } = { }→name为undefined,不是ReferenceError - 函数参数解构常被忽略默认值作用域:
function f({ x = 1 } = {}) { return x; },调用f()才触发默认值,f({})则x为undefined
对象操作看着简单,但展开和解构的“浅”特性、默认值的触发条件、属性访问的动态性,这几处最容易在真实项目里埋下隐性 bug。
# javascript
# java
# js
# json
# 区别
# 作用域
# red
# Object
# NULL
# 运算符
# 构造函数
# 标识符
# const
# 递归
# 继承
# class
# undefined
# function
# 对象
# 严格模式
# this
# bug
# 默认值
# 重命名
# 三种
# 报错
# 只能用
# 最常用
# 复用
# 看着
# 多个
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
宙斯浏览器视频悬浮窗怎么开启 边看视频边操作其他应用教程
Laravel的契約(Contracts)是什么_深入理解Laravel Contracts与依赖倒置
如何用腾讯建站主机快速创建免费网站?
EditPlus中的正则表达式实战(5)
Linux后台任务运行方法_nohup与&使用技巧【技巧】
Edge浏览器提示“由你的组织管理”怎么解决_去除浏览器托管提示【修复】
大同网页,大同瑞慈医院官网?
Win11怎么查看显卡温度 Win11任务管理器查看GPU温度【技巧】
如何在VPS电脑上快速搭建网站?
Claude怎样写约束型提示词_Claude约束提示词写法【教程】
javascript事件捕获机制【深入分析IE和DOM中的事件模型】
Python自然语言搜索引擎项目教程_倒排索引查询优化案例
如何解决hover在ie6中的兼容性问题
Laravel如何生成URL和重定向?(路由助手函数)
如何破解联通资金短缺导致的基站建设难题?
Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制
HTML透明颜色代码怎么让图片透明_给img元素加透明色的技巧【方法】
弹幕视频网站制作教程下载,弹幕视频网站是什么意思?
Laravel怎么实现前端Toast弹窗提示_Laravel Session闪存数据Flash传递给前端【方法】
C语言设计一个闪闪的圣诞树
详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)
java ZXing生成二维码及条码实例分享
如何为不同团队 ID 动态生成多个独立按钮
网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?
高配服务器限时抢购:企业级配置与回收服务一站式优惠方案
敲碗10年!Mac系列传将迎来「触控与联网」双革新
Laravel如何实现API版本控制_Laravel版本化API设计方案
如何用西部建站助手快速创建专业网站?
香港服务器部署网站为何提示未备案?
关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)
Laravel如何集成微信支付SDK_Laravel使用yansongda-pay实现扫码支付【实战】
iOS验证手机号的正则表达式
Python并发异常传播_错误处理解析【教程】
javascript中对象的定义、使用以及对象和原型链操作小结
网易LOFTER官网链接 老福特网页版登录地址
Laravel如何操作JSON类型的数据库字段?(Eloquent示例)
免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?
Android中Textview和图片同行显示(文字超出用省略号,图片自动靠右边)
广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?
Linux网络带宽限制_tc配置实践解析【教程】
如何注册花生壳免费域名并搭建个人网站?
Laravel如何处理CORS跨域请求?(配置示例)
微信小程序 HTTPS报错整理常见问题及解决方案
rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted
微信推文制作网站有哪些,怎么做微信推文,急?
Swift开发中switch语句值绑定模式
制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?
javascript中的数组方法有哪些_如何利用数组方法简化数据处理
js实现获取鼠标当前的位置
Laravel Octane如何提升性能_使用Laravel Octane加速你的应用


