JavaScript中使用多层级的对象属性有什么比较优雅的方式

首页 / 常见问题 / 低代码开发 / JavaScript中使用多层级的对象属性有什么比较优雅的方式
作者:低代码工具 发布时间:24-12-30 09:36 浏览量:7056
logo
织信企业级低代码开发平台
提供表单、流程、仪表盘、API等功能,非IT用户可通过设计表单来收集数据,设计流程来进行业务协作,使用仪表盘来进行数据分析与展示,IT用户可通过API集成第三方系统平台数据。
免费试用

JavaScript中使用多层级对象属性的比较优雅的方式包括使用点符号和方括号结合访问、结构化分配(Destructuring Assignment)、使用?.运算符(Optional ChAIning)、使用?.运算符配合??运算符(Nullish Coalescing)、以及使用函数封装来处理属性访问。在这些方法中,结构化分配因其提供了清晰、简洁的语法来从对象中提取多个属性而十分受欢迎且广泛使用。

结构化分配让你可以从对象中抽取出一部分属性,并直接为其指定变量名。这样不仅代码看起来更为整洁,也降低了出错的可能性,因为你不需要重复编写长长的属性链来获取所需的值。使用结构化分配,代码不但更加易读,也便于后续的维护。

一、结构化分配(DESTRUCTURING ASSIGNMENT)

结构化分配可以简化多层级属性的访问,并能针对嵌套对象提取所需的值。当你需要从一个嵌套较深的对象中提取多个属性,通常会使用结构化分配。

例如,假设有一下对象:

const user = {

name: "John Doe",

contact: {

email: "johndoe@example.com",

phone: {

home: "123-456-7890",

work: "098-765-4321"

}

}

};

通常你可能需要这样获取电话号码:

const homePhone = user.contact.phone.home;

const workPhone = user.contact.phone.work;

利用结构化分配,上述过程可以优雅地转换为:

const { contact: { phone: { home: homePhone, work: workPhone } } } = user;

结构化分配这种方式减少了代码重复,并且使代码更加一目了然。

二、使用?.运算符(OPTIONAL CHAINING)

随着ECMAScript 2020 (ES11)的加入,JavaScript提供了一个新的特性:Optional Chaining。使用?.运算符可以优雅地判断多层级对象属性是否存在,避免在属性不存在时导致的错误。

在没有Optional Chaining之前,访问嵌套对象的属性可能需要进行多次的判空操作:

if (user && user.contact && user.contact.phone) {

const homePhone = user.contact.phone.home;

}

现在,使用?.运算符,可以简单地这样写:

const homePhone = user.contact?.phone?.home;

只有当useruser.contact以及user.contact.phone都存在时,homePhone才会被赋值,大大简化了代码。

三、使用?.??运算符(NULLISH COALESCING)

结合Optional Chaining和Nullish Coalescing运算符??,你可以在查询不到属性值时提供一个默认值。这在处理可能未定义的嵌套属性时非常有用。

例如,如果我们想要获取用户的家庭电话,但是如果该字段未定义,希望返回一个默认值:

const homePhone = user.contact?.phone?.home ?? 'No Home Phone';

这里,如果homenullundefined,则homePhone将被设置为'No Home Phone'。

四、函数封装

有时候,即便是上述优雅的方法也未必能满足需求,特别是当你需要对属性访问逻辑进行复用时。这时,你可以将属性访问逻辑封装到一个函数中。

例如,获得用户的家庭电话这一逻辑可以封装成:

function getHomePhone(user) {

return user.contact?.phone?.home ?? 'No Home Phone';

}

这样,每次需要获取家庭电话时,只需调用getHomePhone(user)即可。

五、使用库和工具

除了原生的JavaScript提供的方法,有时候你也可以使用一些库来简化深层属性的访问。例如,lodash库的_.get()函数可以安全地访问深嵌套的路径,并允许设置一个默认值来处理未定义的情况。

// 使用lodash的_.get方法

const homePhone = _.get(user, 'contact.phone.home', 'No Home Phone');

实践中,选择适合的访问方式取决于你的具体需求以及代码的环境。通常而言,结合结构化分配和Optional Chaining 是一种在现代JavaScript编程中常用且兼顾效率和可读性的优雅方式。而函数封装则为不同的属性访问提供了更高的复用性,同时库的使用则在你需要对现有代码进行大规模操作时更加方便。

相关问答FAQs:

如何在JavaScript中优雅地访问多层级对象属性?

  • 1. 使用点操作符或方括号操作符访问: JavaScript中,可以使用点操作符(.)或方括号操作符([])来访问多层级的对象属性。使用点操作符的方式更简洁直观,但是当属性名包含特殊字符或者是变量时,需要使用方括号操作符来进行访问。

  • 2. 使用可选链操作符(?.): 如果在多层级的对象属性访问过程中某个属性为undefined或null,使用传统方式会导致程序出错。为了避免这种情况,可以使用可选链操作符(?.),它会在属性不存在时返回undefined,而不是抛出错误。

  • 3. 使用解构赋值: 在访问多层级的对象属性时,可以使用解构赋值语法来提取所需的属性值。解构赋值能够快速、简洁地从对象中提取多个属性,并将它们赋值给独立的变量。

  • 4. 使用Lodash库的get方法: Lodash是一个常用的JavaScript工具库,其中提供了许多实用的函数。其中,get方法可以帮助我们优雅地访问多层级对象属性。使用get方法,只需传递对象和属性路径即可,它会在属性不存在时返回undefined,而不会导致程序出错。

  • 5. 使用Proxy代理对象: Proxy是JavaScript中的一个功能强大的特性,可以用于拦截并自定义对对象的操作。通过使用Proxy代理对象,我们可以定义一个处理器来拦截对象属性的访问,从而实现优雅地访问多层级对象属性的方式。

最后建议,企业在引入信息化系统初期,切记要合理有效地运用好工具,这样一来不仅可以让公司业务高效地运行,还能最大程度保证团队目标的达成。同时还能大幅缩短系统开发和部署的时间成本。特别是有特定需求功能需要定制化的企业,可以采用我们公司自研的企业级低代码平台织信Informat。 织信平台基于数据模型优先的设计理念,提供大量标准化的组件,内置AI助手、组件设计器、自动化(图形化编程)、脚本、工作流引擎(BPMN2.0)、自定义API、表单设计器、权限、仪表盘等功能,能帮助企业构建高度复杂核心的数字化系统。如ERP、MES、CRM、PLM、SCM、WMS、项目管理、流程管理等多个应用场景,全面助力企业落地国产化/信息化/数字化转型战略目标。 版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们微信:Informat_5 处理,核实后本网站将在24小时内删除。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系邮箱:hopper@cornerstone365.cn 处理,核实后本网站将在24小时内删除。

最近更新

为什么很多人宁愿 excel 贼 6,也不愿意去用 python
01-07 14:14
C#程序如何调用Python程序
01-07 14:14
python 编程如何实现条件编译
01-07 14:14
为什么可以用CMD安装Python的第三方库
01-07 14:14
如何线上部署用python基于dlib写的人脸识别算法
01-07 14:14
Python 的 Tuple 怎么使用
01-07 14:14
python 的 Task 如何封装协程
01-07 14:14
怎么用Python进行变形监测时间序列数据的小波分析
01-07 14:14
linux 系统环境下 python 多版本间切换的方法有哪些
01-07 14:14

立即开启你的数字化管理

用心为每一位用户提供专业的数字化解决方案及业务咨询

  • 深圳市基石协作科技有限公司
  • 地址:深圳市南山区科技中一路大族激光科技中心909室
  • 座机:400-185-5850
  • 手机:137-1379-6908
  • 邮箱:sales@cornerstone365.cn
  • 微信公众号二维码

© copyright 2019-2024. 织信INFORMAT 深圳市基石协作科技有限公司 版权所有 | 粤ICP备15078182号

前往Gitee仓库
微信公众号二维码
咨询织信数字化顾问获取最新资料
数字化咨询热线
400-185-5850
申请预约演示
立即与行业专家交流