Optional Chaining 可选连语法介绍

Optional Chaining(可选链)是ES2020中新增的语法,旨在简化JavaScript中访问可能不存在的属性或方法时的代码书写,下面我来为你详细解释一下这个语法。

1.什么是 Optional Chaining?

在不使用可选链语法的情况下,我们在访问一个复杂对象时,需要对每一级属性的存在性做逐一检查,以免出现“不可读属性”的错误。而可选链语法可以帮助我们简化这个操作。

2.怎么使用 Optional Chaining?

可选链语法是通过在属性或方法名之后加上 "?“ 实现。如果属性或方法存在,则正常访问它们;如果不存在,则返回undefined而不会报错。

3.应用场景

可选链语法在以下场景特别有用:

  • 访问复杂对象的属性或方法,有可能不存在的情况
  • 通过短路操作避免深层嵌套的条件判断
  • 更为优雅和简洁地进行空值判断
    下面我来为你列举10个代码示例,让你更好地理解它:
// 1. 访问复杂对象的属性或方法
const user = {
  name: "小明",
  address: {
    province: "北京",
  },
};

console.log(user.address?.city); // undefined
console.log(user?.address?.province); // 北京

// 2. 短路操作
const data = {
  user: {
    address: {
      city: "北京"
    }
  }
};

console.log(data.user?.address?.city); // 北京
console.log(data?.user?.name); // undefined

// 3. 数组索引值不存在的情况
const arr = [1, 2, 3];
console.log(arr[3]?.name); // undefined

// 4. Map 对象的键值不存在的情况
const map = new Map();
map.set("a", "apple");
console.log(map.get("b")?.name); // undefined

// 5. 函数调用
const obj = {
  foo: () => {
    console.log("hello world")
  },
}

obj.foo?.();

// 6. 在模板字面量中使用可选链语法
const user = {
  name: "小明",
}

console.log(`用户的年龄是${user?.age}`);

// 7. 链式调用
const user = {
  name: "小明",
  address: {
    province: "北京",
  },
  getInfo() {
    return `我叫${this.name},我的家乡是${this.address?.province}`;
  }
};

console.log(user.getInfo()); // 我叫小明,我的家乡是北京

// 8. 在条件语句中使用可选链语法
const element = document.querySelector("#element");

if (element?.classList?.contains("active")) {
  console.log("该元素包含 active 类");
}

// 9. 在默认值中使用可选链语法
const user = {};
const name = user.name ?? "匿名用户";
console.log(name);

// 10. 可选链语法和解构赋值结合使用
const user = {
  name: "小明",
  address: {
    province: "北京",
  }
};

const { name, age, address: { province } = {} } = user;
console.log(province);
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值