ES11引入可选链操作符(?.),用于安全访问深层嵌套对象属性、调用可能不存在的方法或访问数组元素,遇null/undefined即返回undefined而不报错;常与空值合并操作符??配合提供默认值。

ES11(即 ECMAScript 2020)是 JavaScript 在 2020 年发布的标准版本,它引入了几个实用的新特性,其中最常用、影响最广的就是可选链操作符(Optional Chaining Operator,?.)。它能帮你安全地访问深层嵌套对象的属性,避免因中间某层为 null 或 undefined 而抛出错误。
可选链操作符 ?. 是什么
可选链操作符允许你在访问对象属性或调用方法时,自动检查中间路径是否有效。只要链中任意一环是 null 或 undefined,整个表达式就立即返回 undefined,而不会报错。
常见使用场景包括:
访问嵌套对象属性:user?.address?.city —— 如果 user 或 address 不存在,不报错,直接返回 undefined 调用可能不存在的方法:obj?.method?.() —— 先检查 obj 和 method 是否存在,再执行 访问数组元素(配合括号语法):arr?.[0] —— 若 arr 为 null,也不报错
它解决了什么老问题
在 ES11 之前,要安全访问 a.b.c.d,你得层层判断:
立即学习“Java免费学习笔记(深入)”;
const city = a && a.b && a.b.c && a.b.c.d;
或者用 try/catch 包裹,代码冗长且可读性差。可选链让这类逻辑变得简洁直观,语义也更清晰。
注意事项和搭配建议
可选链必须配合空值合并操作符 ?? 使用才更完整——因为 ?. 遇到断链会返回 undefined,而 ?? 可以提供默认值:
user?.name ?? '匿名用户' —— 名字不存在时显示默认值 config?.theme?.color ?? '#333' —— 安全取色,无配置也不崩 注意:?. 不能用于赋值左侧,比如 obj?.prop = value 是语法错误
其他 ES11 重要特性简提
除了可选链,ES11 还包含:
空值合并操作符 ??:仅当左侧为 null 或 undefined 时才用右侧值(区别于 ||) Promise.allSettled():等待所有 Promise 结束(无论成功失败),返回结果数组 BigInt 支持大整数运算:如 123n + 456n globalThis 提供统一全局对象访问方式(替代 window、global、self 等)
以上就是javascript的ES11是什么_可选链操作符是什么?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1544572.html
微信扫一扫
支付宝扫一扫