这个小技巧完全改变了访问JavaScript嵌套对象的方式!


全文共2513字,预计学习时长7分钟

图源:unsplash

 

JavaScript以众多技巧出名,了解JavaScript的所有技巧几乎不可能。最近在浏览JavaScript的相关文件,阅读相关话题时我又发现了一个从没见过的功能点。我大概不是最后一个学到这个技巧的人,所以我想与各位分享。

 

它完全改变了我访问嵌套对象的方式!希望它能够帮助到你们。

 

技巧

 

这个技巧就叫做可选链。它实际上是一个操作符,写法是 ?.。根据Mozilla网站文件,可选链操作符的功能是:允许读取位于连接对象链深处的属性的值,而不必明确验证链中的每个引用是否有效。

 

简而言之,可选链操作符大大简化了对嵌套对象的访问。直接看这个例子,帮助你更好地理解可选链操作符的作用。

 

假如有对象“房子(house)”如下:

 

const house = {  price: 1000000,  currency:  USD ,  address: {    city:  New York ,    street:  Main street ,    postal_code:  1234 AB ,    state: {      name:  New York ,      abbreviation:  N.Y.     }  },  owner: {    name: "John Doe"  }}

通常要按照如下方式访问对象属性:

 

const currency = house.currencyconst price = house.priceconst owner = house.owner.name

这是读取对象值的基础。如果房子没有主人呢?我们将无法读取不存在的命名属性,而最后一行代码会引起错误。要想弥补这一点,可以这样做:

 

const owner = house.owner ? house.owner.name : null

高手们可以使用空值合并运算符:

 

const owner = house.owner.name ?? null

这串代码的问题在于,即使房子这个对象没有主人,它也不会停止运行。看看下面这个例子:

 

const house = {  price: 1000000,  currency:  USD ,  address: {    city:  New York ,    street:  Main street ,    postal_code:  1234 AB ,    state: {      name:  New York ,      abbreviation:  N.Y.     }  },  owner: null}

使用空值合并运算符会造成错误,因为它不能读取属性中为空的命名(name)。使用三元运算符可以运行第一个例子。但如果要探索的属性是多层嵌套的,还需要挨个检查是否存在,那么代码会很冗长,也无法读取。

 

比如,检查所在州:

 

const state = house.address &&house.address.state ? house.address.state.name : null

如你所见,这行代码变得非常长,无法读取。这时可选链操作符就派上了用场。有了它就不再需要检查某个属性是否存在,从而保持代码简明易懂。如果属性不存在则会返回“undefined”。操作符实际看起来是这样的:

 

const city = house?.address?.city // "New York"const nonExisting = house?.roof?.material // Undefinedconst houseNumber = house?.address?.number // Undefinedconst state = house?.address?.state?.abbreviation // "N.Y."

是不是一下子就变得很简洁明了!

 

图源:unsplash

例一尝试探索“address”属性下“city”属性的值。因为这个属性存在,“城市”属性将会被返回,和使用house.address.city来获取值一样的。

 

例二尝试获得房顶(roof)建材的信息。然而“house”对象下没有“roof”这一属性,因此返回的是“undefined”,“houseNumber”属性也是同理。虽然“house”对象有“address”属性,这个属性却不包含“number”属性——也就是这里返回了“undefined”的原因。

 

你也可以使用可选链操作符来动态查询属性,这时需要使用括号:

 

const someProperty = obj?.[ property-  + propertyName]

也可以与空值合并运算符一起使用。如果要为一个变量设定默认值,例证如下:

 

const ownerName = house?.owner?.name ?? "Unknownowner"

函数

目前只是将可选链操作符与对象结合。但它也可以与函数结合使用。可以用来调取不存在的方法,就像这样:

 

const result = someObject.customMethod?.();

适配

 

老浏览器支持(如IE浏览器)不支持可选链操作符,和其他现代的JavaScript功能点一样。新浏览器如谷歌、火狐、Opera以及Safari都是支持可选链的,但这不妨碍可选链的使用,需要时可在浏览器中添加polyfill。

 

                            

使用可选链操作符可以在不确认嵌套对象中每一个引用是否有效的情况下访问链接深处的对象。它最大的优点是运行起来简洁漂亮,不仅适用于对象,也能调用可能不存在的方法。

 

但请谨记,它不能在IE浏览器中运行——和其他现代JavaScript功能点一样。这些老式浏览器需要添加polyfill才能运行可选链。

 

JavaScript常学常新,总有新彩蛋夹在里面!


推荐阅读专题

留言点赞发个朋友圈

我们一起分享AI学习与发展的干货

编译组:岳馨妍、张天一

相关链接:

https://levelup.gitconnected.com/this-trick-changed-the-way-i-access-nested-objects-in-javascript-bc8ead3a7015

如转载,请后台留言,遵守转载规范

推荐文章阅读

ACL2018论文集50篇解读

EMNLP2017论文集28篇论文解读

2018年AI三大顶会中国学术成果全链接

ACL2017论文集:34篇解读干货全在这里

10篇AAAI2017经典论文回顾

长按识别二维码可添加关注

读芯君爱你

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值