JavaScript中的可选链

简介: 可选链"?."首先,可选链是一种访问嵌套对象属性的安全方式,即使中间的属性不存在也不会出现错误。那么什么是属性不存在呢?

可选链"?."

首先,可选链是一种访问嵌套对象属性的安全方式,即使中间的属性不存在也不会出现错误。

那么什么是属性不存在呢?

举个例子吧:例如此时我们代码里面有一个user对象,里面存储了我们用户的地址,以及街道地址。

let user = {
    address:{
        city:'重庆';
        street:'渝北';
    }
}
复制代码

这个时候,我们去获取user.address不会报错,获取user.address.street也不会报错。

但是如果,对象里面没有address这个属性的时候,那么当我们调用user.address.street的时候,就会报错。

let user = {};
alert(user.address.street);//报错
复制代码

在很多的实际开发当中,我们并不希望得到的一个报错,我们更希望是一个undefined(表示没有该属性)。这个时候我们就需要用到可选链这个小家伙。

可选链

?.:当可选链前面的值为undefined或者null时,它就会停止运算,并且返回undefined

举个例子:

let user = {};
alert(user.address.street);//报错(1)
alert(user.address?.street);//undefined(2)
复制代码

在这段代码中,(1)输出一个报错,但是(2)输出一个undefined。这是因为在执行(2)的时候,遇到?.的时候,判断address是否存在,很明显user是一个空对象,所以属性address并不存在,最后输出undefined

注意:

  • ?.:只会对它前面的值成为可选值,也就是只会判断前面的值是否存在;它不会对后面的值产生影响。
  • 不要过渡的使用可选链,因为使用可选链会将可能出错的地方给掩盖掉(只输出一个undefined),这将会导致后面我们调试更加困难。
  • 可选链前面的变量必须要先声明,不然将会报错。

短路效应

前面我们说过,可选链只会对其前面的值起作用,对后面的值没有影响。

如果可选链前面的值为undefined或者null的时候,会直接跳过后面的值,直接输出undefined,这就是短路效应。

扩展

可选链不是一个运算符,它是一个特殊的语法结构,它还可以有其他的变体:

  • ?.():

let userSayHi = {
    sayHi:function(){
        alert('hi');
    }
};
let userTest = {};
userSayHi.sayHi?.();//hi
userTest.sayHi?.();//undefined
复制代码

这里首先会检查对象里面有没有sayHi这个属性。在userTest这里没有该属性,所以直接输出undefined.

  • ?.[]:

let userSayHi = {
    sayHi:function(){
        alert('hi');
    }
};
let userTest = {};
userSayHi.sayHi?.['sayHi']();//hi
userTest.sayHi?.['sayHi']();//undefined
复制代码

这里的原理同上。

最后:

一个小知识点:我们可以使用可选链来安全的读取或者删除,但是却不能写入,也就是可选链不能在赋值语句的左侧。这将会报错。


相关文章
|
5月前
|
JavaScript 前端开发 安全
javascript中的可选链操作符
javascript中的可选链操作符
|
5月前
|
JavaScript 前端开发
javascript函数表达式
javascript函数表达式
|
5月前
|
JavaScript 前端开发
JavaScript:解构
JavaScript:解构
62 2
|
JavaScript 前端开发
JavaScript 为什么要进行变量提升,它导致了什么问题?
JavaScript 为什么要进行变量提升,它导致了什么问题?
|
JavaScript 前端开发
JavaScript的“&&”和“||”操作符
JavaScript的“&&”和“||”操作符
60 0
|
JavaScript 前端开发
JavaScript:new操作符
JavaScript:new操作符
69 0
|
JavaScript 前端开发
JavaScript 立即执行函数
JavaScript 立即执行函数
|
JavaScript 前端开发
JavaScript立即执行函数
当圆括号出现在匿名函数的末尾想要调用函数时,它会默认将函数当成是函数声明。
108 0
JavaScript立即执行函数
|
JavaScript C语言
JavaScript-操作符2
关系操作符、加性操作符、乘操作符等
112 0
JavaScript-操作符2
|
存储 JavaScript C语言
JavaScript-操作符
自增、自减、按位与、按位或等操作符。
57 0
JavaScript-操作符