空值合并运算符(??)及其使用场景

这篇具有很好参考价值的文章主要介绍了空值合并运算符(??)及其使用场景。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

空值合并操作符(??) 是一个逻辑操作符,当左侧的操作数为 null 或者 undefined 时,返回其右侧操作数,否则返回左侧操作数。

与逻辑或操作符(||) 不同,逻辑或操作符会在左侧操作数为假值时返回右侧操作数。也就是说,如果使用 || 来为某些变量设置默认值,可能会遇到意料之外的行为。比如为假值(例如,‘’ 或 0)时。

const foo = null ?? 'default string';  
console.log(foo);  
// expected output: "default string"  
  
const baz = 0 ?? 42;  
console.log(baz);  
// expected output: 0

示例场景

使用空值合并操作符

在这个例子中,我们使用空值合并操作符为常量提供默认值,保证常量不为 null 或者 undefined。

const nullValue = null;  
const emptyText = ""; // 空字符串,是一个假值,Boolean("") === false  
const someNumber = 42;  
  
const valA = nullValue ?? "valA 的默认值";  
const valB = emptyText ?? "valB 的默认值";  
const valC = someNumber ?? 0;  
  
console.log(valA); // "valA 的默认值"  
console.log(valB); // ""(空字符串虽然是假值,但不是 null 或者 undefined)  
console.log(valC); // 42

为变量赋默认值

以前,如果想为一个变量赋默认值,通常的做法是使用逻辑或操作符(||):

let foo;  
 
//  foo is never assigned any value so it is still undefined  
let someDummyText = foo || 'Hello!';

然而,由于 || 是一个布尔逻辑运算符,左侧的操作数会被强制转换成布尔值用于求值。任何假值(0, ‘’, NaN, null, undefined)都不会被返回。这导致如果你使用0,''或NaN作为有效值,就会出现不可预料的后果。

let count = 0;  
let text = "";  
  
let qty = count || 42;  
let message = text || "hi!";  
console.log(qty);     // 42,而不是 0  
console.log(message); // "hi!",而不是 ""

空值合并操作符可以避免这种陷阱,其只在第一个操作数为null 或 undefined 时(而不是其它假值)返回第二个操作数:

let myText = ''; // An empty string (which is also a falsy value)  
  
let notFalsyText = myText || 'Hello world';  
console.log(notFalsyText); // Hello world  
  
let preservingFalsy = myText ?? 'Hi neighborhood';  
console.log(preservingFalsy); // '' (as myText is neither undefined nor null)

短路

与 OR 和 AND 逻辑操作符相似,当左表达式不为 null 或 undefined 时,不会对右表达式进行求值。文章来源地址https://www.toymoban.com/news/detail-721985.html

function A() { console.log('函数 A 被调用了'); return undefined; }  
function B() { console.log('函数 B 被调用了'); return false; }  
function C() { console.log('函数 C 被调用了'); return "foo"; }  
  
console.log( A() ?? C() );  
// 依次打印 "函数 A 被调用了"、"函数 C 被调用了"、"foo"  
// A() 返回了 undefined,所以操作符两边的表达式都被执行了  
  
console.log( B() ?? C() );  
// 依次打印 "函数 B 被调用了"、"false"  
// B() 返回了 false(既不是 null 也不是 undefined)  
// 所以右侧表达式没有被执行

到了这里,关于空值合并运算符(??)及其使用场景的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【JavaScript】JavaScript 运算符 ④ ( 逻辑运算符 | 逻辑与运算符 && | 逻辑或运算符 || | 逻辑非运算符 ! )

    JavaScript 中的 逻辑运算符 的作用是 对 布尔值 进行运算 , 运算完成 后 的 返回值 也是 布尔值 ; 逻辑运算符 的 使用场景 : 条件控制语句 , 控制程序分支 ; 循环控制语句 , 控制程序循环 ; 逻辑 运算符 列举 : : 逻辑与运算 , 两个操作数都为 true , 最终结果才为 true , 只要有一个操

    2024年03月20日
    浏览(54)
  • 【JavaScript】JavaScript 运算符 ⑤ ( 赋值运算符 | 基础赋值运算符 与 复合赋值运算符 )

    JavaScript 赋值运算符种类 : 基础赋值运算符 : 等于 : = ; 复合赋值运算符 : 加等 : += 减等 : -= 乘等 : *= 除等 : /= 取模等 : %= 有符号左移等 : = 有符号右移等 : = 无符号左移等 : = 无符号右移等 : = 在 JavaScript 语言中 , \\\" 赋值运算符 \\\" 的 作用是 为 变量 分配值 ; 最基础的 \\\" 赋值运算

    2024年03月25日
    浏览(52)
  • JavaScript中一元运算符、三元运算符、循环

    前置自增: 后置自增: 区别 1.单独使用前置和后置没有区别。 2.前置自增:先自加再使用(记忆口诀:++在前,先加) 1.while循环 2.for循环 3.while循环和for循环区别 4.for循环嵌套 1.while循环 2.for循环 1.for循环执行代码 *作用:重复执行代码 *好处:把声明起始值、循环条件、变

    2024年02月04日
    浏览(45)
  • 位运算符及其相关操作详解

    前言:由于位运算符是直接对二进制数操作,因此对二进制、八进制、十六进制不甚了解的小伙伴建议先看这篇二进制、八进制、十六进制与十进制的相互关系,这样阅读本篇时将事半功倍 位运算是对 计算机存储的二进制序列的相应位进行操作 位运算的 操作数必须是整数型

    2024年02月05日
    浏览(42)
  • JavaScript =+运算符

    += 是 js 的加法运算,表达式 A += B 表示: A = A + B 。 如下: JavaScript 中 =+ 是一种特殊的赋值,表达式 A =+ B 表示:将 B 转化为数字赋值给 A 。 = 是赋值, + 代表后面的数字为正数;同理, =- 代表后面的数字为负数。 相当于告诉编译器,即将赋值的数值类型为数字类型,不要

    2024年02月12日
    浏览(54)
  • 【JavaScript】相等运算符(== 和 ===)

    如果x和y的类型相同,JavaScript会用equals 方法比较这两个值或对象。 没有出现在表格中的情况都会返回 false。(表格中的方法都是内部规定的) 对于 toNumber 方法: 对于 toPrimitive 方法: 第二行代码之所以为 false,就是因为 true 先转化为数 1,因此开始比较 \\\'aaa\\\' == 1 ;然后 ‘

    2024年02月07日
    浏览(55)
  • Javascript-中常用运算符

    目录 数据类型 常见运算 算术运算符 比较运算符 逻辑运算符 赋值运算符 自增/减运算符 三目运算符 位运算符 在 JS 中有以下两大类: 基本数据类型 数值类型(Number) 整数 (int) 浮点数(float) 布尔类型(Boolean),有两个值:true 和 false 字符串(String),它可以是单引号包

    2024年01月24日
    浏览(47)
  • JavaScript系列从入门到精通系列第九篇:JavaScript中赋值运算符和关系运算符以及Unicode编码介绍

    文章目录 一:赋值运算符 1:= 2:+= 3:-= 4:*= 5:/= 6:%= 二:关系运算符  1:数值类型关系运算 (一): (二):= (三): (四):= 2:其他类型关系运算 三:Unicode编码表         =右侧的值可以赋值给左侧的变量。         上边这两个写法是一样的。                 

    2024年02月08日
    浏览(60)
  • C++所有运算符及其优先级表格

    运算符 运算符介绍 优先级 :: 范围解析 1 () [] - . 圆括号、方括号、箭头、点号 2 ++ -- 后缀递增、后缀递减 2 typeid const_cast dynamic_cast reinterpret_cast static_cast 类型名称、常量类型转换、动态类型转换、重新解释的类型转换、静态类型转换 2 ! ~ ++ -- + - * (type) sizeof new delete 非、按位

    2024年02月13日
    浏览(39)
  • Python运算符列表及其优先顺序、结合性

    本文表格对Python中运算符的优先顺序进行了总结,从最高优先级(最先绑定)到最低优先级(最后绑定)。相同单元格内的运算符具有相同优先级。除非句法显式地给出,否则运算符均指二元运算。 相同单元格内的运算符均从左至右分组。但是,小部分运算符是从右至左分组

    2024年02月15日
    浏览(57)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包