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 返回的不确定结构

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

对象展开只做一层浅拷贝,不递归;不能展开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语法;嵌套解构需严格对齐结构。

  • 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。


# 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加速你的应用