JS 基础 (三) 可选链
浏览 1362 | 评论 0
无所事事彼得兔
2020年06月08日

var、let、const的区分

1.var定义的变量,没有块的概念,可以跨块访问, 不能跨函数访问。

2.let定义的变量,只能在块作用域里访问,不能跨块访问,也不能跨函数访问。

3.const用来定义常量,使用时必须初始化(即必须赋值),只能在块作用域里访问,实际值不能修改,也不能重复定义,泛型可以修改子参数。

可选链操作符

可选链操作符( ?. )允许读取位于连接对象链深处的属性的值,而不必明确验证链中的每个引用是否有效。?. 操作符的功能类似于 . 链式操作符,不同之处在于,在引用为空(nullish ) (null 或者 undefined) 的情况下不会引起错误,该表达式短路返回值是 undefined。与函数调用一起使用时,如果给定的函数不存在,则返回 undefined。

let test = {
    name:"box",
    cat:{
       name:"orange"     
    }    
}

const dogName = test.dog?.name;
console.log(dogName );
//输出:undefined

console.log(test.someNonExistentMethod?.());
//输出:undefined

console.log(test.cat?.name);
//输出:orange

语法

obj?.prop
obj?.[expr]
arr?.[index]
func?.(args)

描述

let nestedProp = obj.first && obj.first.second;

为了避免报错,在访问obj.first.second之前,要保证 obj.first 的值既不是 null,也不是 undefined。如果只是直接访问 obj.first.second,而不对 obj.first 进行校验,则有可能抛出错误。

而我们常见的的做法就是使用 if() 来判断是否存在相应的字段是否存在,再执行操作,但是这样会导致多重判断存在,
例如:

if(obj.first){
    if(obj.first.second){
        if(obj.first.second.third){
            return true;
        }
    }
}

如果将这个代码嵌入 for() 中做逻辑处理的话,会使处理时间飙升,极其影响效率。

而有了可选链操作符(?.),在访问 obj.first.second 之前,不再需要明确地校验 obj.first 的状态,再并用短路计算获取最终结果:

let nestedProp = obj.first?.second;

可选链和表达式

let nestedProp = obj?.['prop' + 'Name'];

可选链不能用于赋值

let object = {};
object?.property = 1; // Uncaught SyntaxError: Invalid left-hand side in assignment

可选链访问数组元素

let arrayItem = arr?.[42];

例子

基本例子

如下的例子在一个不含 bar 成员的 Map 中查找 bar 成员的 name 属性,因此结果是 undefined。

let myMap = new Map();
myMap.set("foo", {name: "baz", desc: "inga"});

let nameBar = myMap.get("bar")?.name;

短路计算

当在表达式中使用可选链时,如果左操作数是 null 或 undefined,表达式将不会被计算,例如:

let potentiallyNullObj = null;
let x = 0;
et prop = potentiallyNullObj?.[x++];

console.log(x); // x 将不会被递增,依旧输出 0

连用可选链操作符

可以连续使用可选链读取多层嵌套结构:

let customer = {
  name: "Carl",
  details: {
    age: 82,
    location: "Paradise Falls" // details 的 address 属性未有定义
  }
};
let customerCity = customer.details?.address?.city;

// … 可选链也可以和函数调用一起使用
let duration = vacations.trip?.getTime?.();

使用空值合并操作符

let customer = {
  name: "Carl",
  details: { age: 82 }
};
let customerCity = customer?.city ?? "暗之城";
console.log(customerCity); // “暗之城”//相当于给customerCity赋值"暗之城"

浏览器兼容性

QQ图片20210329100539.png

文章参考:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Operators/Optional_chaining

本文作者:无所事事彼得兔
本文链接:https://www.3dcw.cn/index.php/archives/496/
最后修改时间:2021-09-01 10:33:31
本站未注明转载的文章均为原创,并采用 CC BY-NC-SA 4.0 授权协议,转载请注明来源,谢谢!
评论
与本文无关评论请发留言板。请不要水评论,谢谢。
textsms
支持 Markdown 语法
email
link
评论列表
暂无评论
arrow_back 上一篇
JS 基础 (二)
arrow_forward 下一篇
没有了