可选链操作符(?.)解决深层嵌套属性访问时因 NULL/undefined 导致的报错问题,支持属性访问、方法调用、数组索引三种场景,但仅限读取操作且不可赋值。

javaScript 可选链操作符(?.)是一种安全访问嵌套 对象 属性的语法,它能在访问链中任意环节为 null 或 undefined 时自动停止并返回 undefined,避免报错。
可选链能解决什么问题?
在没有可选链前,访问类似 user.profile.address.city 这样的深层属性,必须层层判断:
❌ 容易出错的写法:
const city = user && user.profile && user.profile.address && user.profile.address.city;
代码冗长、可读性差,还容易漏判某一层。
立即学习“Java 免费学习笔记(深入)”;
三种常见用法场景
1. 访问对象属性
用 ?. 替代 .,遇到空值就短路:
-
user?.profile?.address?.city→ 安全,返回undefined而非报错 -
user?.['profile']?.['address']?.city→ 支持方括号动态属性名
2. 调用方法?. 后接函数调用,只在函数存在时执行:
-
obj?.getData?.()→ 如果getData是undefined,不调用,也不报错 -
arr?.[0]?.toString?.()→ 先取首项,再确保是对象且有toString方法
3. 访问数组元素
结合中括号使用,防止索引越界或数组为空:
-
list?.[0]?.name→list为空、[0]不存在,都返回undefined -
items?.[index]?.value→ 动态索引也适用
注意事项和边界情况
可选链不是万能的,要注意这些细节:
- 只能用于“读取”操作,不能用于赋值(
obj?.prop = value会报语法错误) - 左侧表达式必须是合法引用,不能是原始值(如
5?.toString()在 严格模式 下会报错) - 与空值合并操作符
??搭配更实用:user?.name ?? '匿名用户' - 不触发 getter,除非该属性确实被访问到(即前面所有层级都非空)
基本上就这些。用好 ?. 能让嵌套取值变得简洁又健壮,不复杂但容易忽略。