JavaScript中的可选链操作符

在JavaScript中,?. 被称为可选链操作符(Optional Chaining Operator)。它允许你访问对象的深层属性而不必显式地检查每一层属性是否存在。如果链中的某个属性不存在,表达式将短路返回undefined,而不是抛出一个TypeError异常。

例如,假设你有一个对象a,它可能包含一个属性b,而b又可能包含属性c

javascript 复制代码
const a = {
  b: {
    c: 1
  }
};

使用传统的访问方式,你需要这样检查属性:

javascript 复制代码
const c = a && a.b && a.b.c;

但是使用可选链操作符,你可以简化为:

javascript 复制代码
const c = a?.b?.c;

如果aa.ba.b.c中的任何一个不存在,c将被赋值为undefined,而不是抛出错误。这使得代码更加简洁和安全。可选链操作符也可以与函数调用和new操作符一起使用:

javascript 复制代码
const result = a?.b?.doSomething();
const instance = new a?.b?.MyClass();

如果a.ba.b.MyClass不存在,resultinstance将分别是undefinedTypeError(因为new操作符需要一个有效的构造函数)。

面试题:

javascript 复制代码
const person = {
	firstName: "Lydia",
	lastName: "Hallie",
	pet: {
		name: "Mara",
		breed: "Dutch Tulip Hound"
	},
	getFullName() {
		return `${this.firstName} ${this.lastName}`;
	}
};

console.log(person.pet?.name);
console.log(person.pet?.family?.name);
console.log(person.getFullName?.());
console.log(person.getLastName?.());

输出是:Mara undefined Lydia Hallie undefined

相关推荐
froginwe117 分钟前
R 基础运算
开发语言
醉城夜风~7 分钟前
[数据结构]堆详解
开发语言·数据结构
堕落年代10 分钟前
Vue主流的状态保存框架对比
前端·javascript·vue.js
没资格抱怨12 分钟前
el-pagination的使用说明
javascript·vue.js·elementui
冴羽22 分钟前
Svelte 最新中文文档教程(22)—— Svelte 5 迁移指南
前端·javascript·svelte
青红光硫化黑31 分钟前
React基础之useEffect
javascript·react.js·ecmascript
17´34 分钟前
Qt从入门到入土(八) -打包Qt程序
开发语言·c++·qt
AI+程序员在路上35 分钟前
QT显示网页控件QAxWidget、QWebEngineView及区别
开发语言·qt
bin915338 分钟前
DeepSeek 助力 Vue3 开发:打造丝滑的表格(Table)之添加列宽调整功能,示例Table14基础固定表头示例
前端·javascript·vue.js·ecmascript·deepseek
南玖yy40 分钟前
C语言柔性数组深度解析:动态内存管理的艺术
c语言·开发语言·柔性数组