JavaScript中的高效运算符:?.、||、?? 以及 ??=

探索JavaScript中的高效运算符:?.、||、?? 以及 ??=

在前端开发的日常中,我们经常需要处理各种数据逻辑,确保代码既健壮又高效。JavaScript为我们提供了一系列简洁而强大的运算符,帮助我们以更优雅的方式处理变量的空值、默认值等问题。今天,我们就来深入探讨三种这样的高效运算符:可选链操作符 ?.、逻辑或操作符 ||、空值合并操作符 ?? 以及它们的变体 ??=。这些运算符在处理不确定或可能为空的属性访问及提供默认值时尤其有用。

1. 可选链操作符 ?.

定义与用法
可选链操作符 ?. 允许你安全地访问深层嵌套的属性,而不必担心中间某个属性不存在导致的错误。如果访问路径上的任何部分为 null 或 undefined,整个表达式会立即短路返回 undefined 而不是抛出错误。

const user = {
  // profile: { email: 'example@example.com' }
};

// 使用可选链,即使 profile 未定义也不会报错
const userEmail = user?.profile?.email;
console.log(userEmail); // 输出:undefined
优势
  • 减少代码冗余:避免了多次检查变量是否为 null 或 undefined 的需求。
  • 提升安全性:防止因访问不存在的属性而导致的运行时错误。

2. 逻辑或操作符 ||

定义与用法

逻辑或操作符 || 在JavaScript中常用于设置默认值。当操作符左侧的值被解释为“假”(如 nullundefinedfalse0、空字符串等)时,它会返回右侧的操作数。

let name = '';
const defaultName = 'Guest';

// 使用逻辑或设置默认值
const displayName = name || defaultName;
console.log(displayName); // 输出:Guest
注意事项
  • 当左侧操作数为 0'' 等“假值”但实际业务场景中应被视作有效值时,使用 || 可能会导致意料之外的结果。

3. 空值合并操作符 ??

定义与用法

空值合并操作符 ?? 类似于 ||,但仅在左侧操作数为 null 或 undefined 时才返回右侧操作数,对于 0''false 等其他“假值”,则依然返回左侧操作数。

let age = 0;

// 使用空值合并操作符设置默认值
const defaultAge = age ?? 25;
console.log(defaultAge); // 输出:0
优势

相比 ||?? 更精确地处理了“有意的空值”与“缺失的值”之间的区别,提供了更细粒度的控制。

4. 空值合并赋值操作符 ??=

定义与用法

??= 是ES2021引入的新特性,它允许你为一个可能为 null 或 undefined 的变量设置默认值,并直接赋值。

let score = null;
score ??= 100; // 等同于:if (score === null || score === undefined) score = 100;
console.log(score); // 输出:100

优势
提高代码的简洁性和可读性,特别是在多个变量需要设置默认值的场景下。

总结
通过本文的介绍,我们了解了JavaScript中的四种高效运算符:.?、||、?? 和 ??=,它们在处理不确定数据和提供默认值方面各具特色。合理运用这些运算符,不仅可以使我们的代码更加简洁、安全,还能有效提升开发效率和代码质量。在实际开发中,根据具体场景选择最合适的运算符,将是我们提升代码健壮性的关键。

五 ||和?? 的区别

||

function(obj){
    var a = obj || {}
}
 
等价于
function(obj){
    var a;
    if(obj === 0 || obj === "" || obj === false || obj === null || obj === undefined){
 	    a = {}
    } else {
	    a = obj;
    }
}

??

function(obj){
    var a = obj ?? {}
}
 
等价于
function(obj){
    var a;
    if( obj === null || obj === undefined){
 	    a = {}
    } else {
	    a = obj;
    }
}

参考:ES6---4个强大JavaScript运算符(??、??=、?.、?:、!!)_js ??运算符-CSDN博客

  • 9
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值