当前位置: 首页 > news >正文

改进 JavaScript 条件语句,探索可以替代 if...else 的 7 种方式!

image.png

当优化 JavaScript 代码时,条件语句是一个经常需要思考和改进的关键部分。if...else 结构虽然是我们常用的条件语句之一,但当代码逻辑变得复杂,if...else 结构可能会导致代码冗长、难以维护和理解。因此,了解并掌握优化 if...else 结构的方法对于提高代码的可读性、可维护性和性能至关重要。

本篇文章中将根据不同的条件语句场景,提供各种不同 JavaScript 条件语句的写法,重点关注如何替代 if...else 的写法,从简单的技巧和出发,目的是提高代码的简洁性和可读性。

image.png

1. 使用三元运算符

三元运算符是 JavaScript 中的一种条件表达式,可以用于简化 if...else 语句的写法。它的语法是:

condition ? expr1 : expr2;

其中,condition 是一个条件表达式,如果条件为真,则返回 expr1,否则返回 expr2。

下面用一个简单的示例,说明如何使用三元运算符优化条件语句对比:

示例:使用三元运算符优化条件语句对比

// 原始的 if...else 语句
let num = 0;
let result;
if (num > 0) {result = "positive";
} else if (num < 0) {result = "negative";
} else {result = "zero";
}
console.log(result);

使用三元运算符优化后

let num = 0;
let result = num > 0 ? "positive" : num < 0 ? "negative" : "zero";
console.log(result);

对于简单的条件语句,三元运算符是一个不错的选择,使用三元运算符可以使代码更加简洁和清晰,但在某些情况下也可能会影响代码的可读性。对于复杂的条件逻辑,建议慎重使用,也可以选用其他方式替代。

2. 使用逻辑与(&&)和逻辑或(||)

逻辑与(&&)和逻辑或(||)也是 JavaScript 中用于处理条件语句的方式之一,与三元运算符类似,逻辑与(&&)和逻辑或(||)可以帮助简化一些简单条件判断的写法。

示例:使用逻辑与(&&)和逻辑或(||)优化条件语句对比

// 原始的 if 语句
let num = 10;
let result;
if (num > 0) {result = "positive";
} else {result = "non-positive";
}
console.log(result);

使用逻辑与和逻辑或优化后

let num = 10;
let result = (num > 0 && "positive") || "non-positive";
console.log(result);

在上面的示例中,利用逻辑与(&&)和逻辑或(||)的短路特性来简化条件判断。

  • 当 num 大于 0 时,表达式 num > && 'positive' 的结果为 'positive',所以最终 result 的值为 'positive'

  • 当 num 不大于 0 时,表达式 num > 0 && 'positive'的结果为 false,然后逻辑或(||)操作符会返回结果'non-positive'

注意:利用逻辑与(&&)和逻辑或(||)优化条件语句的方法适用于简单的条件判断,在复杂的条件逻辑下,也可能会降低代码的可读性。在编写代码时需要根据具体情况选择合适的方式来处理条件语句,以确保代码的清晰和易于维护。

3. 使用对象字面量(Object Literal)

使用对象字面量(Object Literal)通过将不同条件对应的值存储在对象字面量中,然后通过读取对象属性的方式来获取对应的值,使代码更加清晰和易于维护。

示例:使用对象字面量优化条件语句对比

// 原始的 if-else 语句
let color = "red";
let fruit;if (color === "red") {fruit = "apple";
} else if (color === "yellow") {fruit = "banana";
} else {fruit = "unknown";
}
console.log(fruit);

使用对象字面量优化后

let color = "red";
let fruit ={red: "apple",yellow: "banana",}[color] || "unknown";console.log(fruit);

在上面的示例中,使用对象字面量来优化条件语句。通过将不同条件对应的值存储在对象字面量中,然后通过读取对象属性的方式来获取对应的值,能够简化 if-else 结构。在这个例子中,根据 color 的不同取值,直接获取对应水果名称的逻辑。

使用对象字面量的优化方法可以使代码更加简洁和易读,特别是在多个条件需要判断并返回不同值的情况下,可以替代冗长的 if-else 结构。当然,也需要根据具体情况选择合适的优化方式,以确保代码的清晰和可维护性。

4. 使用对象映射表(Map)

使用对象映射表(Map)适用于需要根据不同条件执行不同操作的情况,将不同条件和对应操作存储在 Map 中,根据条件获取对应的操作执行。

示例:使用对象映射表(Map)优化条件语句对比

// 原始的 if-else 语句
let condition = "B";if (condition === "A") {console.log("执行A操作");
} else if (condition === "B") {console.log("执行B操作");
} else if (condition === "C") {console.log("执行C操作");
}

使用对象映射表(Map)优化后

let conditionsMap = new Map([["A", () => console.log("执行A操作")],["B", () => console.log("执行B操作")],["C", () => console.log("执行C操作")],
]);if (conditionsMap.has(condition)) {conditionsMap.get(condition)();
}

通过上述的代码,使用对象映射表(Map)将不同条件和对应操作存储在 Map 中,根据条件获取对应的操作执行。

使用对象映射表(Map)优化条件语句的方法可以简化代码逻辑,提高代码的可读性和可维护性。特别适用于需要根据多个条件执行不同的情况,可以将条件和对应操作一一映射存储,通过 Map 快速获取执行对应操作。

5. 使用 Array.includes

使用 Array.includes 方法适用于需要判断某个值是否包含在一个数组中的情况,大大简化了条件判断的过程。

示例:使用 Array.includes 优化条件语句对比

// 原始的 if-else 语句
let fruit = "apple";
let isFruit = false;if (fruit === "apple" || fruit === "banana" || fruit === "orange") {isFruit = true;
}
console.log(isFruit);

使用 Array.includes 优化后

let fruit = "apple";
let fruits = ["apple", "banana", "orange"];
let isFruit = fruits.includes(fruit);
console.log(isFruit);

在上面的示例中,原始的 if-else 结构需要逐个判断 fruit 是否等于 'apple'、'banana' 或 'orange',而使用 Array.includes 方法则可以直接判断 fruit 是否包含在 fruits 数组中,从而简化了条件判断的过程。

使用 Array.includes 方法的优化方法适合于需要判断某个值是否属于一个集合的情况,避免了重复的多次判断。当需要判断值是否包含在某个数组中时,可以考虑使用 Array.includes 方法来优化条件语句。

注意:Array.includes  属于 ES6+ 中新增的方法,因此在较旧的浏览器版本中可能不被支持,为了确保网页在各种浏览器中的兼容性,如果需要使用 Array.includes 方法,可以考虑使用 Babel 或其他类似的工具来转译代码,将 ES6 的语法转换为能在更多浏览器中运行的 ES5 代码。

image.png

6. 使用 Array.every

使用 Array.every 方法适用于需要对数组中的所有元素进行条件判断的情况。

示例:使用 Array.every 优化条件语句对比

// 原始的 if-else 语句
let numbers = [2, 4, 6, 8];
let allEven = true;for (let i = 0; i < numbers.length; i++) {if (numbers[i] % 2 !== 0) {allEven = false;break;}
}
console.log(allEven);

使用 Array.every 优化后

let numbers = [2, 4, 6, 8];
let allEven = numbers.every((num) => num % 2 === 0);
console.log(allEven);

原始的 if-else 结构通过遍历数组中的所有元素,判断是否全部为偶数,而使用 Array.every 方法则可以直接对数组中的每个元素应用条件判断,并返回是否所有素都满足条件的结果。

使用 Array.every 方法的优化方法适合于需要对数组中所有元素进行条件判断的情况,能够大幅度的简化代码逻辑。当需要判断数组中所有元素是否满足某个条件时,可以考虑使用 Array.every 方法来优化条件语句。

7. 使用 switch...case

使用 switch...case 适用于多个条件需要进行严格相等比较的情况。

示例:使用 switch...case 优化条件语句对比

// 原始的 if-else 语句
let fruit = "apple";
let color = "";if (fruit === "apple") {color = "red";
} else if (fruit === "banana") {color = "yellow";
} else if (fruit === "orange") {color = "orange";
} else {color = "unknown";
}
console.log(color);

使用 switch...case 优化后

let fruit = "apple";
let color = "";switch (fruit) {case "apple":color = "red";break;case "banana":color = "yellow";break;case "orange":color = "orange";break;default:color = "unknown";
}
console.log(color);

在上面的示例中,原始的 if-else 结构包含多个条件判断,而使用 switch...case 结构可以更清晰地将不同情况分支进行处理,适用于多个严格相等比较的情况。

使用 switch...case 语句的优化方法适合于需要根据不同值进行严格相等比较的情况,能够简化逻辑,提高代码的可读性和可维护性。当需要对多个条件进行严格相等比较时,可以考虑使用 switch...case 语句来优化条件语句。

 

相关文章:

改进 JavaScript 条件语句,探索可以替代 if...else 的 7 种方式!

当优化 JavaScript 代码时&#xff0c;条件语句是一个经常需要思考和改进的关键部分。if...else 结构虽然是我们常用的条件语句之一&#xff0c;但当代码逻辑变得复杂&#xff0c;if...else 结构可能会导致代码冗长、难以维护和理解。因此&#xff0c;了解并掌握优化 if...else…...

全新子比主题7.9.2开心版 子比主题最新版源码

内容目录 一、详细介绍二、效果展示1.部分代码2.效果图展示 三、学习资料下载 一、详细介绍 wordpress zibll子比主题7.9.2开心版 修复评论弹授权 可做付费下载站 含wordpress搭建视频教程zibll子比主题安装视频教程支付配置视频教程&#xff0c;视频都是语音讲解&#xff0c;…...

Kafka之消费者组与消费者

消费者&#xff08;Consumer&#xff09;在Kafka的体系结构中是用来负责订阅Kafka中的主题&#xff08;Topic&#xff09;&#xff0c;并从订阅的主题中拉取消息后进行处理。 与其他消息中间件不同&#xff0c;Kafka引入一个逻辑概念——消费组&#xff08;Consumer Group&…...

Damn-Vulnerable-Drone:一款针对无人机安全研究与分析的靶机工具

关于Damn-Vulnerable-Drone Damn-Vulnerable-Drone是一款针对无人机安全研究与分析的靶机工具&#xff0c;广大研究人员可以利用该环境工具轻松学习、研究和分析针对无人机安全态势。 Damn Vulnerable Drone 基于流行的 ArduPilot/MAVLink 架构&#xff0c;其中故意留下了各种…...

项目模块三:Socket模块

一、模块设计 1、套接字编程常用头文件展示 #include <sys/types.h> #include <sys/socket.h> #include <netinet/in.h> #include <arpa/inet.h> #include <unistd.h> #include <fcntl.h> 2、成员函数设计 &#xff08;1&#xf…...

Unity-Shader-语义

1、从程序传给顶点函数&#xff1a; POSITION&#xff1a;顶点坐标&#xff08;模型空间下&#xff09; NORMAL&#xff1a;法线向量&#xff08;模型空间下&#xff09; TANGENT&#xff1a;切线向量&#xff08;模型空间下&#xff09; TEXCOORD0~n&#xff1a;纹理坐标 …...

MFC工控项目实例二十四模拟量校正值输入

承接专栏《MFC工控项目实例二十三模拟量输入设置界面》 对模拟量输入的零点校正值及满量程对应的电压值进行输入。 1、在SenSet.h文件中添加代码 #include "BtnST.h" #include "ShadeButtonST.h"/ // SenSet dialogclass SenSet : public CDialog { // Co…...

analysis-ik分词器

analysis-ik分词器 1、安装离线在线 2、使用配置拓展词典 3、测试ik_smartik_max_word 1、安装 离线 使用离线安装下载地址https://release.infinilabs.com/analysis-ik/stable/找到对应es版本的ik分词器、下载zip后放到/elasticsearch/plugins/ik文件夹下。重启es即可生效 …...

开源的、基于内存的键值存储数据库redis详细介绍

目录 一、Redis的概述 1、概述 2、特点 &#xff08;1&#xff09;基本特性 &#xff08;2&#xff09;数据结构 &#xff08;3&#xff09;运行环境 二、Redis的重要作用 1、缓存 2、会话存储 3、消息队列 4、计数器 5、分布式锁 6、排行榜 7、实时数据处理 三、…...

三种容器 std::vector、std::map、std::unordered_set 的对比分析

目录 1.添加元素 1.1 std::vector 1.2 std::map 1.3 std::unordered_set 2. 查找元素 2.1 std::vector 2.2 std::map 2.3 std::unordered_set 3. 遍历容器 3.1 std::vector 使用范围基for循环(range-based for loop) 使用迭代器: 3.2 std::map 3.3 std::unord…...

Nuxt3 SSR 服务端渲染部署 PM2 全流程(Nest.js 同理)

项目打包 我们以 Nuxt3 项目为例子&#xff1a; 项目打包 执行 npm run build &#xff0c; 生成的 .output 文件夹就是部署产物&#xff08;目前不支持中文路径&#xff09;执行 npm run preview 可以本地预览效果 方式一&#xff1a;使用 Node 部署 需要服务器安装 Nod…...

如何轻松使用pip安装Git仓库中的私有Python模块(使用pip和Git仓库发布和安装私有Python模块)

文章目录 📖 介绍 📖🏡 演示环境 🏡📒 Git模块 📒📝 Git仓库要求🔖 项目目录结构🔖 文件说明📝 编写setup.py📝 配置MANIFEST.in📝 推送代码到Git仓库📝 使用pip安装模块🔖 使用用户名和密码🔖 使用Personal Access Token (PAT)🔖 示例📝 更…...

写 R 包教程

R R 包开发 | 保姆级教程-CSDN博客 https://www.prestevez.com/post/r-package-tutorial/ 1、加载开发所需 R 包 library(usethis) library(devtools) library(roxygen2) 2、在当前工作路径创建 R 包 usethis::create_package("myRpkg") # 在当前路径创建 my…...

【java】数组(超详细总结)

目录 一.一维数组的定义 1.创建数组 2.初始化数组 二.数组的使用 1.访问数组 2.遍历数组 3.修改数据内容 三.有关数组方法的使用 1.toString 2. copyOf 四.查找数组中的元素 1.顺序查找 2.二分查找binarySearch 五.数组排序 1.冒泡排序 2.排序方法sort 六.数组逆置…...

@KafkaListener注解

KafkaListener(topics "${xxxx}", containerFactory "xxx") public void consume(String message) {service.save(xx); }在 Spring Boot 中&#xff0c;使用 KafkaListener 注解消费 Kafka 消息时&#xff0c;如果 service.save(cleanWikiSource) 抛出异…...

2025年计算机视觉研究进展与应用国际学术会议 (ACVRA 2025)

2025年计算机视觉研究进展与应用国际学术会议 (ACVRA 2025) 2025 International Conference on Advances in Computer Vision Research and Applications 重要信息 2025年3月28-30日 南京 一轮截稿日期&#xff1a;2024年11月30日 EI检索稳定 早投稿&#xff0c;早审稿&a…...

第二代GPT-SoVITS V2:让声音克隆变得简单

随着人工智能技术的飞速发展&#xff0c;AI声音克隆已经成为一种趋势&#xff0c;广泛应用于各个领域。为了满足更多用户的需求&#xff0c;第二代GPT-SoVITS V2应运而生&#xff0c;它由RVC变声器创始人“花儿不哭”与AI音色转换技术Sovits开发者Rcell联合开发&#xff0c;是一…...

基于x86_64汇编语言简单教程6: 变量,常量,与运算

目录 变量 为未初始化的数据分配存储空间 多重初始化 常量 equ指令 &#xff05;assign 指令 &#xff05;define指令 算数指令 inc 自增指令 dec指令 ADD和SUB指令 imul/mul和idiv/div 实践&#xff1a;我们来写一个简单的一位数加法器 NASM逻辑指令 AND 指令 …...

Vue-router 路由守卫执行流程图

vue-router 路由守卫执行的流程图&#xff08;个人理解&#xff09; 图1 - 图2...

ES6 中函数参数的默认值

概述&#xff1a; ES 允许给函数的参数赋初始值&#xff1b; 代码示例及相关说明&#xff1a; <!DOCTYPE html> <html> <head> <meta charset"utf-8"> <title>函数参数默认值</title> </head> <body> <script&g…...

python打卡day49

知识点回顾&#xff1a; 通道注意力模块复习空间注意力模块CBAM的定义 作业&#xff1a;尝试对今天的模型检查参数数目&#xff0c;并用tensorboard查看训练过程 import torch import torch.nn as nn# 定义通道注意力 class ChannelAttention(nn.Module):def __init__(self,…...

树莓派超全系列教程文档--(61)树莓派摄像头高级使用方法

树莓派摄像头高级使用方法 配置通过调谐文件来调整相机行为 使用多个摄像头安装 libcam 和 rpicam-apps依赖关系开发包 文章来源&#xff1a; http://raspberry.dns8844.cn/documentation 原文网址 配置 大多数用例自动工作&#xff0c;无需更改相机配置。但是&#xff0c;一…...

多场景 OkHttpClient 管理器 - Android 网络通信解决方案

下面是一个完整的 Android 实现&#xff0c;展示如何创建和管理多个 OkHttpClient 实例&#xff0c;分别用于长连接、普通 HTTP 请求和文件下载场景。 <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns:android"http://schemas…...

【CSS position 属性】static、relative、fixed、absolute 、sticky详细介绍,多层嵌套定位示例

文章目录 ★ position 的五种类型及基本用法 ★ 一、position 属性概述 二、position 的五种类型详解(初学者版) 1. static(默认值) 2. relative(相对定位) 3. absolute(绝对定位) 4. fixed(固定定位) 5. sticky(粘性定位) 三、定位元素的层级关系(z-i…...

涂鸦T5AI手搓语音、emoji、otto机器人从入门到实战

“&#x1f916;手搓TuyaAI语音指令 &#x1f60d;秒变表情包大师&#xff0c;让萌系Otto机器人&#x1f525;玩出智能新花样&#xff01;开整&#xff01;” &#x1f916; Otto机器人 → 直接点明主体 手搓TuyaAI语音 → 强调 自主编程/自定义 语音控制&#xff08;TuyaAI…...

【分享】推荐一些办公小工具

1、PDF 在线转换 https://smallpdf.com/cn/pdf-tools 推荐理由&#xff1a;大部分的转换软件需要收费&#xff0c;要么功能不齐全&#xff0c;而开会员又用不了几次浪费钱&#xff0c;借用别人的又不安全。 这个网站它不需要登录或下载安装。而且提供的免费功能就能满足日常…...

在Mathematica中实现Newton-Raphson迭代的收敛时间算法(一般三次多项式)

考察一般的三次多项式&#xff0c;以r为参数&#xff1a; p[z_, r_] : z^3 (r - 1) z - r; roots[r_] : z /. Solve[p[z, r] 0, z]&#xff1b; 此多项式的根为&#xff1a; 尽管看起来这个多项式是特殊的&#xff0c;其实一般的三次多项式都是可以通过线性变换化为这个形式…...

Golang——6、指针和结构体

指针和结构体 1、指针1.1、指针地址和指针类型1.2、指针取值1.3、new和make 2、结构体2.1、type关键字的使用2.2、结构体的定义和初始化2.3、结构体方法和接收者2.4、给任意类型添加方法2.5、结构体的匿名字段2.6、嵌套结构体2.7、嵌套匿名结构体2.8、结构体的继承 3、结构体与…...

Qt 事件处理中 return 的深入解析

Qt 事件处理中 return 的深入解析 在 Qt 事件处理中&#xff0c;return 语句的使用是另一个关键概念&#xff0c;它与 event->accept()/event->ignore() 密切相关但作用不同。让我们详细分析一下它们之间的关系和工作原理。 核心区别&#xff1a;不同层级的事件处理 方…...

Cilium动手实验室: 精通之旅---13.Cilium LoadBalancer IPAM and L2 Service Announcement

Cilium动手实验室: 精通之旅---13.Cilium LoadBalancer IPAM and L2 Service Announcement 1. LAB环境2. L2公告策略2.1 部署Death Star2.2 访问服务2.3 部署L2公告策略2.4 服务宣告 3. 可视化 ARP 流量3.1 部署新服务3.2 准备可视化3.3 再次请求 4. 自动IPAM4.1 IPAM Pool4.2 …...