美文网首页
js中可选链操作符——?.

js中可选链操作符——?.

作者: 黎明的叶子 | 来源:发表于2021-07-22 15:00 被阅读0次

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

当尝试访问可能不存在的对象属性时,可选链操作符将会使表达式更短、更简明。在探索一个对象的内容时,如果不能确定哪些属性必定存在,可选链操作符也是很有帮助的。

const adventurer = {
  name: 'Alice',
  cat: {
    name: 'Dinah'
  }
};

const dogName = adventurer.dog?.name;
console.log(dogName);
// expected output: undefined

console.log(adventurer.someNonExistentMethod?.());
// expected output: undefined
let nestedProp = obj.first && obj.first.second;

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

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

let nestedProp = obj.first?.second;

摘自:可选链操作符

相关文章

  • ES6中(?.、??)运算符的使用

    可选链操作符( ?. ) 可选链操作符(?.)允许读取位于连接对象链深处的属性的值,而不必明确验证链中的每个引用是...

  • 可选链 操作符(?. 与 ??)

    一、 ?. 可选链操作符(?.)允许读取位于连接对象链深处的属性值,而不必明确验证链中的每个引用是否有效。 js会...

  • js开发中常用的高效技巧

    1.可选链操作符 可选链操作符( ?. )允许读取位于连接对象链深处的属性的值,而不必明确验证链中的每个引用是否有...

  • 小技巧

    js 可选链操作符 obj?.key?.key 等价于 obj && obj.key && obj.key.key

  • JavaScript 可选链操作符(?.)

    可选链操作符( ?. )允许读取位于连接对象链深处的属性的值,而不必明确验证链中的每个引用是否有效。?. 操作符的...

  • JS 中强大的操作符

    1.0 数值操作符_ 2.0 逗号运算符 , 3.0零合并操作符 ?? (||) 4.0可选链操作符?. (&&...

  • js ??和?. 可选链操作符( ?. ) 空值合并操作符(??

    看了一个项目代码,项目中报语法错误: 可选链操作符( ?. ) 选链操作符( ?. )允许读取位于连接对象链深处的...

  • ES6 可选链操作符

    可选链操作符( ?. )允许读取位于连接对象链深处的属性的值,而不必明确验证链中的每个引用是否有效。?. 操作...

  • ES11中的可链选操作符?.

    可选链操作符( ?. )允许读取位于连接对象链深处的属性的值,而不必明确验证链中的每个引用是否有效。详细用法参考:...

  • node.js 14新特性

    1 Optional Chaining(可选链) 2 Nullish Coalescing(空值合并)逻辑或操作符...

网友评论

      本文标题:js中可选链操作符——?.

      本文链接:https://www.haomeiwen.com/subject/eyfpmltx.html