JavaScript 中的 ?? 和 ?.

举报
搞前端的半夏 发表于 2022/06/30 21:47:04 2022/06/30
【摘要】 是什么空值合并运算符( Nullish Coalescing Operator )是一个逻辑运算符,使用 ?? 表示!主要作用是检查一个值是否是null或者undefined,如果是则返回运算符后面的值,你可以把这个后面的值当作备胎!类似相亲,会判断你是不是穷逼,如果你是穷逼,则会毫不犹豫的选择备胎!例如:X??YY如果这里的X 不是null或者undefined,否则返回Y!我们可以将*...

是什么

空值合并运算符( Nullish Coalescing Operator )是一个逻辑运算符,使用 ?? 表示!主要作用是检查一个值是否是null或者undefined,如果是则返回运算符后面的值,你可以把这个后面的值当作备胎!类似相亲,会判断你是不是穷逼,如果你是穷逼,则会毫不犹豫的选择备胎!

例如:X??YY

如果这里的X 不是null或者undefined,否则返回Y!

我们可以将**??**等价于 (a!==null and a!==undefined)? a : b

示例

const a = 0 ?? 1;

根据空值合并运算符的定义,这里a的是0。

const a = undefined ?? 1
const b = null ?? 1

这个例子中的a都是1。

与||的区别

逻辑或运算符的作用是当左边的值是假值是,返回右边的值!

假值包括下面几种

  • NaN
  • 0
  • " " 或 ’ ’
  • null
  • undefined
  • false

在??之前,我们给一个变量赋默认值,我们的做法是使用||

let variable = 形参 || 备用值;

然后使用||,会出现0这个可以作为有效值的,被忽略掉!

let count = 0;

let variable = count || 42;

这里variabl的值就会是42,但是我们明明想要的是0。而空值合并运算符则可以避免这种情况!!!

?? 与 ?.

两个??是空值合并运算。一个?加 . 叫做 可选链 操作符。可选链操作符,允许我们读取对象深层不存在的属性。

例如:我们有一个user对象,他有一个name属性。

let user{
    name :"张三"
}

当我们想访问user.age,这个不存在的属性是,并不会报错!

image-20220602215228188

我们访问更深一层的user.age.newAge,就会直接报错!

image-20220602215310076

我们给user.age可选链操作符,你会发现他不报错了!

user.age?.newage

image-20220602215555706

当然可选连最适合应用场景应该是API调用的时候,假设我们user对象中,本来有一个getName()方法,但是某一天,这个方法被注释掉了!

image-20220602220338884

image-20220602220414787

碰撞

对于**??**来说,它可以识别null和undefined,而我们的可选链又可以讲错误转成undefined,那么这两者放在一起,是不是可以给深层不存在的属性赋值啦!

const user = {
     name: "张三"
};

console.log(user.age?.newage ?? 18);  
console.log(user.getName?.() ?? "默认名字"); 

image-20220602220630735

总结

  1. 空值合并运算符 在左侧null或为undefined时返回右侧值。

  2. 当你想用假值做默认值,空值合并运算符是首选!

  3. **???.**搭配起来很好用!

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。