空值合并运算符‘两个问号‘与‘||‘的区别和使用

无意中发现'??'这个运算符实在是太好用啦!

是对'||'的扩充,可以按需选择用'||'还是'??'

~(*^▽^*)~

(吐槽一下,竟然把??判为敏感词不让放标题...)

??符号会判断一个参数的值是否是已定义的(defined)

如果是,返回左边(它本身),如果不是,返回右边

a??b

let a;

alert(a ?? b ); //输出b,a未定义

我们可以用'??'来给未定义的变量提供一个默认值,当变量为null/undefined时返回这个变量值

let user;

alert(user ?? "匿名"); // 匿名(user 未定义)

let user = "John";

alert(user ?? "匿名"); // John(user 已定义)

??与||的区别主要在与他们对于值为0、""、false等的判断

|| 返回第一个

?? 返回第一个 已定义的

let height = 0;

alert(height || 100); // 100

alert(height ?? 100); // 0

?? 运算符的优先级非常低,仅略高于 ?=,因此在表达式中使用它时请考虑添加括号

在与 ||&& 一起使用时需要明确添加括号

let x = (1 && 2) ?? 3;

alert(x); // 2
let height = null;

let width = null;

let area = (height ?? 100) * (width ?? 50); // 重要:使用括号

alert(area); // 5000
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值