”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 解锁 JavaScript:逻辑 OR (||) 与空合并运算符 (??)

解锁 JavaScript:逻辑 OR (||) 与空合并运算符 (??)

发布于2024-07-30
浏览:122

Unlocking JavaScript: Logical OR (||) vs Nullish Coalescing Operator (??)

介绍

JavaScript作为最流行的编程语言之一,为开发人员提供了一系列运算符来处理各种逻辑运算。其中,逻辑或 (||) 和空值合并 (??) 运算符是管理默认值和处理空值的基本工具。本文将深入探讨这两个运算符之间的差异、它们的用例,以及实际、复杂的示例来说明它们的用法。

了解逻辑 OR (||) 运算符

JavaScript 中的逻辑 OR (||) 运算符广泛用于返回其操作数中的第一个真值,如果没有一个真值,则返回最后一个值。主要用于设置默认值。

句法

result = operand1 || operand2;

怎么运行的

||运算符从左到右计算,如果第一个操作数为真则返回;否则,它计算并返回第二个操作数。

示例 1:设置默认值

let userInput = '';
let defaultText = 'Hello, World!';

let message = userInput || defaultText;
console.log(message); // Output: 'Hello, World!'

在此示例中,userInput 是一个空字符串(假),因此返回 defaultText。

示例 2:处理多个值

let firstName = null;
let lastName = 'Doe';

let name = firstName || lastName || 'Anonymous';
console.log(name); // Output: 'Doe'

这里,firstName为null(假),因此lastName被返回,因为它是true。

逻辑 OR (||) 运算符的限制

|| 的主要限制运算符的一个缺点是它将多个值视为假值,例如 0、NaN、''、false、null 和 undefined。当这些值应该有效时,这可能会导致意外结果。

引入空值合并 (??) 运算符

Nullish Coalescing (??) 运算符是 JavaScript 的最新补充,在 ES2020 中引入。它旨在处理 null 或 undefined 明确意味着唯一考虑的空值的情况。

句法

result = operand1 ?? operand2;

怎么运行的

这 ??当左侧操作数为 null 或未定义时,运算符返回右侧操作数。否则,它返回左侧操作数。

示例 1:设置默认值

let userInput = '';
let defaultText = 'Hello, World!';

let message = userInput ?? defaultText;
console.log(message); // Output: ''

在本例中,userInput 是一个空字符串,不为 null 或未定义,因此返回。

示例 2:处理空值

let firstName = null;
let lastName = 'Doe';

let name = firstName ?? lastName ?? 'Anonymous';
console.log(name); // Output: 'Doe'

这里,firstName为null,因此lastName被返回,因为它既不是null也不是未定义的。

比较逻辑 OR (||) 和空合并 (??) 运算符

示例 1:比较虚假值

let value1 = 0;
let value2 = '';

let resultOR = value1 || 'default';
let resultNullish = value1 ?? 'default';

console.log(resultOR); // Output: 'default'
console.log(resultNullish); // Output: 0

在此示例中,|| 认为 0 为假。运算符,但它是 ?? 的有效值操作员。

示例 2:同时使用两个运算符

let userInput = null;
let fallbackText = 'Default Text';

let message = (userInput ?? fallbackText) || 'Fallback Message';
console.log(message); // Output: 'Default Text'

这里,userInput为空,所以fallbackText被??使用操作员。然后通过 || 检查结果运算符,但由于 FallbackText 为真,因此返回它。

逻辑 OR (||) 和空合并 (??) 运算符的复杂示例

示例 3:对象的嵌套操作

考虑一个场景,您需要为嵌套对象属性设置默认值。

let userSettings = {
  theme: {
    color: '',
    font: null
  }
};

let defaultSettings = {
  theme: {
    color: 'blue',
    font: 'Arial'
  }
};

let themeColor = userSettings.theme.color || defaultSettings.theme.color;
let themeFont = userSettings.theme.font ?? defaultSettings.theme.font;

console.log(themeColor); // Output: 'blue'
console.log(themeFont); // Output: 'Arial'

在这个例子中,userSettings.theme.color是一个空字符串,所以使用defaultSettings.theme.color。 userSettings.theme.font 为 null,因此使用 defaultSettings.theme.font。

示例 4:具有默认值的函数参数

处理函数参数时,您可能需要为缺少的参数提供默认值。

function greet(name, greeting) {
  name = name ?? 'Guest';
  greeting = greeting || 'Hello';

  console.log(`${greeting}, ${name}!`);
}

greet(); // Output: 'Hello, Guest!'
greet('Alice'); // Output: 'Hello, Alice!'
greet('Bob', 'Hi'); // Output: 'Hi, Bob!'
greet(null, 'Hey'); // Output: 'Hey, Guest!'

在此示例中,名称参数使用 ??如果 name 为 null 或未定义,则使用运算符设置默认值“Guest”。问候语参数使用 ||如果问候语是除 null 或未定义之外的任何虚假值,则运算符设置默认值“Hello”。

示例 5:与可选链结合

可选链接 (?.) 可以与 || 组合和 ??安全地处理深度嵌套的对象属性。

let user = {
  profile: {
    name: 'John Doe'
  }
};

let userName = user?.profile?.name || 'Anonymous';
let userEmail = user?.contact?.email ?? 'No Email Provided';

console.log(userName); // Output: 'John Doe'
console.log(userEmail); // Output: 'No Email Provided'

在此示例中,可选链接可确保如果属性路径的任何部分不存在,则返回未定义,从而防止错误。 ||和 ??然后运算符提供适当的默认值。

最佳实践和用例

  1. 使用||对于广泛违约:

    • 当您需要为一系列虚假条件(例如,空字符串、0、NaN)提供默认值时。
  2. 使用 ??精确的空值检查:

    • 当您特别想要处理 null 或 undefined 而不影响其他虚假值时。
  3. 两者结合:

    • 使用 || 的组合和 ??对于需要明确处理真值/假值和空值的复杂场景。

常见问题解答

逻辑或 (||) 运算符的作用是什么?
逻辑 OR (||) 运算符返回其操作数中的第一个真值,如果没有真值,则返回最后一个操作数。

什么时候应该使用 Nullish Coalescing (??) 运算符?
当您需要专门处理 null 或未定义而不将其他虚假值(如 0 或空字符串)视为 null 时,请使用 Nullish Coalescing (??) 运算符。

我可以同时使用两个运算符吗?
是的,您可以同时使用 ||和 ??一起处理不同类型的值并确保您的代码逻辑有效地涵盖各种情况。

怎么办||处理空字符串?
||运算符将空字符串视为假,因此如果第一个操作数是空字符串,它将返回下一个操作数。

所有浏览器都支持 Nullish Coalescing (??) 运算符吗?
这 ??支持 ES2020 的现代浏览器和环境支持运算符。对于较旧的环境,您可能需要使用像 Babel 这样的转译器。

|| 之间有什么区别和 ??运算符?
主要区别在于||将多个值视为假值(例如 0、''、false),而 ??仅将 null 和 undefined 视为空值。

结论

理解 JavaScript 中逻辑 OR (||) 和空合并 (??) 运算符之间的差异对于编写健壮且无错误的代码至关重要。 ||运算符非常适合广泛的默认场景,而 ??非常适合精确处理空值。通过适当地使用这些运算符,您可以确保您的代码有效地处理各种数据状态,从而提供无缝的用户体验。

版本声明 本文转载于:https://dev.to/itsshaikhaj/unlocking-javascript-logical-or-vs-nullish-coalescing-operator--21hb?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • FCS API 与 Insight Ease:比特币 API 服务的简单比较
    FCS API 与 Insight Ease:比特币 API 服务的简单比较
    如果您热衷于比特币 API,那么选择正确的 API 非常重要。特别是如果您是开发人员、金融分析师或经营一家金融科技公司。您会听到的两个流行名称是 FCS API 和 Insight Ease。但哪一个更好呢?让我们仔细观察一下它们的比较,特别是当涉及到加密货币实时汇率 API、加密货币 API 交...
    编程 发布于2024-11-02
  • 如何在不修改HTML的情况下用JavaScript监听表单提交事件?
    如何在不修改HTML的情况下用JavaScript监听表单提交事件?
    在 JavaScript 中监听表单提交事件而不修改 HTML在本文中,我们解决了在不修改 HTML 的情况下监听表单提交事件的常见挑战必须修改 HTML 代码。我们不依赖 HTML 中的 onClick 或 onSubmit 属性,而是提供纯 JavaScript 解决方案。为了实现这一点,我们利...
    编程 发布于2024-11-02
  • Document.getElementById 与 jQuery $():主要区别是什么?
    Document.getElementById 与 jQuery $():主要区别是什么?
    Document.getElementById vs jQuery $():比较分析深入研究 Web 开发领域时,了解普通版本之间的细微差别JavaScript 和 jQuery 可能至关重要。本文研究了两个看似相同的代码片段之间的细微差别:var contents = document.getEl...
    编程 发布于2024-11-02
  • 在 Java 中使用方法和变量句柄进行运行时对象访问和操作
    在 Java 中使用方法和变量句柄进行运行时对象访问和操作
    反射和方法/var 句柄是 Java 中的两个强大功能,允许开发人员在运行时访问和操作对象。然而,它们在访问和处理对象的方式上有所不同。 让我们看一个如何使用反射来访问类中方法的示例。我们将从一个名为“MyClass”的简单类开始,它有一个私有字符串变量和该变量的 getter 方法。为了创建这个对...
    编程 发布于2024-11-02
  • 如何在 Python 中使用内置函数验证 IP 地址?
    如何在 Python 中使用内置函数验证 IP 地址?
    Python 中的 IP 地址验证验证 IP 地址的有效性是编程中的常见任务。从用户处接收字符串形式的 IP 地址时,必须对其进行验证,以确保它们符合正确的格式和结构。要在 Python 中有效验证 IP 地址,请考虑以下方法:无需手动解析 IP 地址,而是利用套接字模块中的内置 inet_aton...
    编程 发布于2024-11-02
  • 我需要学习编程方面的帮助
    我需要学习编程方面的帮助
    您好,我是一名系统工程专业的学生,​​我觉得我在课程中学到的编程知识不多。我想自学,因为我对这个话题非常感兴趣。这就是我在这个网站上向了解编程的人寻求帮助的原因。如果有人知道学习编程的最佳课程,从基础开始并进步到更专业的水平,那将会有很大的帮助。 我感兴趣的语言: Java JavaScript P...
    编程 发布于2024-11-02
  • 如何将 gorm.Model 集成到具有日期时间支持的 Protocol Buffer 定义中?
    如何将 gorm.Model 集成到具有日期时间支持的 Protocol Buffer 定义中?
    将 gorm.Model 集成到 Protocol Buffer 定义中将 gorm 的 gorm.Model 字段集成到 protobuf 定义中时,由于 proto3 中缺乏日期时间支持,出现了挑战。本文探讨了此问题的解决方案。ProtoBuf 字段类型映射CreatedAt、UpdatedAt...
    编程 发布于2024-11-02
  • 修补您的 Discord 活动的网络请求,以实现顺利的 CSP 合规性
    修补您的 Discord 活动的网络请求,以实现顺利的 CSP 合规性
    通过Discord运行Discord活动时,您可能会遇到内容安全策略(CSP)问题。您可以通过确保网络请求遵循 Discord 代理 规则来修复这些问题。 这可以手动完成...或者你可以让@robojs/patch处理它。 什么是CSP? 内容安全策略 (CSP) 是一种安全标准,...
    编程 发布于2024-11-02
  • 推荐项目:删除课程表查看数据
    推荐项目:删除课程表查看数据
    LabEx 的这个项目释放了数据库管理的力量,提供了在数据库中创建和操作视图的全面学习体验。无论您是崭露头角的数据库管理员还是经验丰富的开发人员,该项目都提供了宝贵的机会来增强您的技能并获得对数据管理世界的实际见解。 深入了解基础知识 在这个项目中,您将踏上了解数据库中视图的核心概念...
    编程 发布于2024-11-02
  • 模拟网络请求变得容易:集成 Jest 和 MSW
    模拟网络请求变得容易:集成 Jest 和 MSW
    Writing unit tests that involve mocking or stubbing API calls can feel overwhelming—I’ve been there myself. In this article, I’ll guide you through a ...
    编程 发布于2024-11-02
  • 使用 Javascript 的哈希映射
    使用 Javascript 的哈希映射
    介绍 哈希映射(Hash Map),也称为哈希表(Hash Table),是一种实现关联数组抽象数据类型的数据结构,是一种可以将键映射到值的结构。 它使用哈希函数来计算存储桶或槽数组的索引,从中可以找到所需的值。 哈希映射的主要优点是它的效率。插入新的键值对、删除键值对以及查...
    编程 发布于2024-11-02
  • HTPX 简介:适用于 JavaScript 和 Node.js 的轻量级多功能 HTTP 客户端
    HTPX 简介:适用于 JavaScript 和 Node.js 的轻量级多功能 HTTP 客户端
    作为开发人员,我们的 Web 应用程序通常需要一个可靠且高效的 HTTP 客户端,无论我们是在浏览器中使用 JavaScript 还是在服务器端使用 Node.js 进行构建。这就是我创建 HTPX 的原因——一个强大的、轻量级的解决方案,旨在简化 HTTP 请求,同时为现代开发提供一系列功能。 在...
    编程 发布于2024-11-02
  • 使用自然语言通过法学硕士生成简单的 Python GUI .... 在不到几分钟的时间内
    使用自然语言通过法学硕士生成简单的 Python GUI .... 在不到几分钟的时间内
    Thought that building Python GUIs took hours of tedious coding? Welcome to an exciting new era! Not only can tools like Github Copilot help with code ...
    编程 发布于2024-11-02
  • Dev、Oops 和 WEBAPP 故事
    Dev、Oops 和 WEBAPP 故事
    作为 DevOps 专业人员开发桌面 Web 应用程序感觉就像在广阔而复杂的海洋中航行。随着技术融合,Web、桌面和基于云的应用程序之间的界限变得模糊,迫使 DevOps 深入传统上由前端占据的领域 终端开发商。选择正确的框架变得至关重要,但挑战往往在于筛选当今可用的众多选项。例如,Vite、Rea...
    编程 发布于2024-11-02
  • 释放您的 Django 潜力:适合 4 人的项目创意和资源
    释放您的 Django 潜力:适合 4 人的项目创意和资源
    Django 时事通讯 - 2024 年 10 月 Django 简介和项目想法 如果您希望开始使用 Django 或提高自己的技能,请考虑以下一些宝贵的资源和项目想法: Django 项目想法 对于那些想要尝试或构建自己的作品集的人来说,Djang...
    编程 发布于2024-11-02

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3