如何简化多个 if 的判断结构

多少算太多?
有些人认为数字就是一,你应该总是用至少一个三元运算符来代替任何单个 if 语句。我并不这样认为,但我想强调一些摆脱常见的 if/else 意大利面条代码的方法。
我相信很多开发人员很容易陷入 if/else 陷阱,不是因为其他解决方案的复杂性,而是因为它遵循这样的自然语言模式:if 执行此操作, else 执行此操作。
等等,什么是三元运算符?
三元运算符与 if/else 并没有革命性的区别,因为它们都是条件操作,但三元运算符会返回一个值,因此可以直接用于赋值。
const greaterThanFive = (8 > 5) ? 'yep' : 'nope';console.log(greaterThanFive); // 'yep'
基本模式只是一个条件,如果为真则返回一个值,如果为假则返回另一个值。
(condition) ? isTruthy : isFalsy
IF/ELSE 的替代方案
让我们从一个场景开始,逐步了解不同解决方案的示例。
我们将从用户输入中获取颜色,并需要将它们转换为一些预设的颜色代码来匹配,以便我们可以更改背景颜色。因此,我们将检查颜色名称字符串,并在匹配时设置颜色代码。
const setBackgroundColor = (colorName) => {let colorCode = '';if(colorName === 'blue') {colorCode = '#2196F3';} else if(colorName === 'green') {colorCode = '#4CAF50';} else if(colorName === 'orange') {colorCode = '#FF9800';} else if(colorName === 'pink') {colorCode = '#E91E63';} else {colorCode = '#F44336';};document.body.style.backgroundColor = colorCode;
};
这个 if/else 就完成了工作。但是我们背负着大量重复逻辑比较 colorName 和重复赋值 colorCode。
Switch 转变
现在我们可以更恰当地将其更改为 switch 语句。它更符合我们正在尝试做的事情的概念;我们有几种想要匹配的字符串情况,如果没有一种情况匹配,则有一个默认值。
const setBackgroundColor = (colorName) => {let colorCode = '';switch(colorName) {case 'blue':colorCode = '#2196F3';break;case 'green':colorCode = '#4CAF50';break;case 'orange':colorCode = '#FF9800';break;case 'pink':colorCode = '#E91E63';break;default:colorCode = '#f44336';};document.body.style.backgroundColor = colorCode;
};
但是 switch 仍然带有大量我们可以不需要的样板文件和重复代码。
Lookup Table 查找表
那么我们真正想要实现什么目标呢?我们需要将十六进制颜色代码分配给颜色名称,因此让我们创建一个将颜色名称作为键、将颜色代码作为值的对象。然后我们可以使用 object[key] 通过颜色名称查找颜色代码。我们需要一个默认值,因此如果没有找到键,则返回默认值的短三元运算符将在创建对象的默认部分时执行此操作。
const colorCodes = {'blue' : '#2196F3','green' : '#4CAF50','orange' : '#FF9800','pink' : '#E91E63','default': '#F44336'
};const setBackgroundColor = (colorName) => {document.body.style.backgroundColor = colorCodes[colorName]? colorCodes[colorName]: colorCodes['default'];
};
现在我们有了一个查找表,可以整齐地列出我们的输入和可能的输出。
这并不是奇迹般地减少了“代码行数”(LOC)(我们从 15 行减少到 20 行,再减少到 12 行)。事实上,其中一些解决方案可能会增加您的 LOC,但我们提高了可维护性、易读性,并且实际上通过仅对默认回退进行一次逻辑检查来降低复杂性。
数据的交易逻辑
在 if/else 或 switch 上使用查找表的最重要成就是我们将比较逻辑的多个实例转换为数据。代码更具表现力;它将逻辑显示为操作。代码更具可测试性;逻辑被减少了。而且我们的比较更容易维护;它们被合并为纯数据。
让我们将五个比较逻辑运算减少为一个,并将我们的值转换为数据。
场景:我们需要将成绩百分比转换为对应的字母成绩。
if/else 很简单;我们从上到下检查成绩是否高于或等于匹配字母成绩所需的成绩。
const getLetterGrade = (gradeAsPercent) => {if(gradeAsPercent >= 90) {return "A";} else if(gradeAsPercent >= 80) {return "B";} else if(gradeAsPercent >= 70) {return "C";} else if(gradeAsPercent >= 60) {return "D";} else {return "F"};
};
但我们一遍又一遍地重复相同的逻辑运算。
因此,让我们将数据提取到一个数组中(以保留顺序)并将每个等级的可能性表示为一个对象。现在我们只需对对象进行一次 >= 比较,并找到数组中第一个匹配的对象。
const gradeChart = [{minpercent: 90, letter: 'A'},{minpercent: 80, letter: 'B'},{minpercent: 70, letter: 'C'},{minpercent: 60, letter: 'D'},{minpercent: 0, letter: 'F'}
];const getLetterGrade = (gradeAsPercent) => {const grade = gradeChart.find((grade) => gradeAsPercent >= grade.minpercent);return grade.letter;
};
开始将您的比较想象为数据
当你需要比较或“检查”数值时,很自然地会想到 if/else,这样你就可以用语言逐步解决问题。但下一次,请试着思考如何将您的值表示为数据,并通过简化逻辑来解释这些数据。
您的代码最终将变得更具可读性、可维护性和目的性,并且其所代表的概念清晰分离。
原文:https://dreith.com/blog/theres-such-a-thing-as-using-too-many-ifs/
相关文章:
如何简化多个 if 的判断结构
多少算太多? 有些人认为数字就是一,你应该总是用至少一个三元运算符来代替任何单个 if 语句。我并不这样认为,但我想强调一些摆脱常见的 if/else 意大利面条代码的方法。 我相信很多开发人员很容易陷入 if/else 陷阱,不是因为其…...
发掘服务器硬件优势:怎样有效管理、维护、更新
1. 概述 服务器是许多信息技术的核心,通过提供计算和存储资源,以用于企业和机构的数据处理和存储。服务器硬件也是服务器的核心组成部分,在服务器架构和配置中扮演着重要角色。 服务器硬件的优势: - 提供更高的性能和处理能力。…...
SD卡备份和烧录ubuntu20.04镜像
设备及系统:nuc幻影峡谷工控机,ubuntu20.04,树莓派4B,SD卡读卡器 一、确定SD卡设备号的两种方法 方法1: 将有ubuntu镜像的SD卡插入读卡器,再将读卡器插入电脑主机,在 工具 中打开 磁盘&#…...
短视频账号矩阵系统/开发 -- -- -- 蒙太奇算法上线
短视频账号矩阵系统,短视频矩阵系统开发3年技术之路,目前已经在技术竞品出沉淀出来,近期技术迭代的新的功能同步喽: php7.4版本,自研框架,有开发文档,类laravel框架 近期剪辑迭代的技术算法&am…...
Docker Stack(堆栈) 部署多服务集群,多服务编排
1、Docker Stack简介 Docker Stack(堆栈) 是在 Swarm 上管理服务堆栈的工具。而在以前文章docker swarm集群搭建 介绍的 Docker Swarm 只能实现对单个服务的简单部署,于是就引出了Docker Stack。 上面我们介绍到 docker-compose:可以在一台机器上使用…...
全国青少年软件编程(Scratch)等级考试二级考试真题2023年12月——持续更新.....
青少年软件编程(图形化)等级考试试卷(二级) 分数:100 题数:37 一、单选题(共25题,共50分) 1.在制作推箱子游戏时,地图是用数字形式储存在电脑里的,下图是一个推箱子地图,地图表示如下: 第一行(111111) 第二行(132231) 第三行(126621) 第四行( ) 第五行(152…...
python基础——异常捕获【try-except、else、finally】
📝前言: 这篇文章主要介绍一下python基础中的异常处理: 1,异常 2,异常的捕获 3,finally语句 🎬个人简介:努力学习ing 📋个人专栏:C语言入门基础以及python入门…...
JAVA面试大全之JVM和调优篇
目录 1、类加载机制 1.1、类加载的生命周期? 1.2、类加载器的层次? 1.3、Class.forName()和ClassLoader.loadClass()区别?...
数据可视化-ECharts Html项目实战(8)
在之前的文章中,我们学习了如何设置散点图涟漪效果与仪表盘动态指针效果。想了解的朋友可以查看这篇文章。同时,希望我的文章能帮助到你,如果觉得我的文章写的不错,请留下你宝贵的点赞,谢谢 今天的文章,会…...
JavaSE:继承和多态(下篇)
目录 一、前言 二、多态 (一)多态的概念 (二)多态实现条件 (三)多态的优缺点 三、重写 (一)重写的概念 (二)重写的规则 (三)重…...
springboot+mybatis项目集成p6spy输出格式化sql日志
本文背景:公司项目框架是基于springboot+mybatis的web项目,由于鄙人在使用过程中发现打印的mybatis日志每次都要粘贴出来,然后再用在线工具的格式化填充参数,很不方便,最近发现那个在线的工具打不开了,更不方便了,因此想有没有直接可以输出的填充好参数的sql语句,当然i…...
yarn安装和使用及与npm的区别
一、yarn安装和使用 要安装和使用yarn,您可以按照以下步骤进行操作: 安装Node.js:首先,您需要在您的计算机上安装Node.js。您可以从Node.js的官方网站(https://nodejs.org/en/download/)下载并安装适用于您…...
【3D-GS】Gaussian Splatting SLAM——基于3D Gaussian Splatting的全网最详细的解析
【3D-GS】Gaussian Splatting SLAM——基于3D Gaussian Splatting的定SLAM 3D-GS 与 Nerf 和 Gaussian Splatting1. 开山之作 Nerf2. 扛鼎之作 3D Gaussian Splatting2.1 什么是3D高斯?高斯由1D推广到3D的数学推导2.2 什么是光栅化?2.3 什么是Splatting?2.4 什么是交叉优化?…...
推荐多样性 - 华为OD统一考试(C卷)
OD统一考试(C卷) 分值: 200分 题解: Java / Python / C++ 题目描述 推荐多样性需要从多个列表中选择元素,一次性要返回N屏数据(窗口数量),每屏展示K个元素(窗口大小),选择策略: 各个列表元素需要做穿插处理,即先从第一个列表中为每屏选择一个元素,再从第二个列表…...
vue基础教程(4)——十分钟吃透vue路由router
同学们可以私信我加入学习群! 正文开始 前言一、路由概念二、路由使用三、创建路由对应的组件四、给整个项目一个入口总结 前言 前面的文章运行成功后,页面显示如下: 在这个页面中,点击Home和About都会切换右面的页面内容&#…...
使用OpenSSL指令测试椭圆曲线签名算法ECDSA
文章目录 小结问题及解决获取secp256r1的公钥和私钥DER格式使用OpenSSL及secp256r1算法获得签名使用OpenSSL及secp256r1算法对签名进行认证 参考 小结 本文记录了使用OpenSSL指令测试椭圆曲线签名算法ECDSA,进行了以下操作:生成椭圆曲线secp256r1 公私密…...
ubuntu之搭建samba文件服务器
1. 在服务器端安装samba程序 sudo apt-get install samba sudo apt-get install smbclient 2.配置samba服务 sudo gedit /etc/samba/smb.conf 在文件末尾追加入以下配置 [develop_share] valid users ancy path /home/ancy public yes writable y…...
P10—P11:Java程序的编译和运行
编译阶段(P10) Java程序的运行包括两个阶段:编译阶段、运行阶段编译阶段主要任务:对Java源程序(以.java为后缀的文件),进行检查其是否符合Java的语法规则。如果符合,则生成字节码文…...
【Docker】Windows中打包dockerfile镜像导入到Linux
【Docker】Windows中打包dockerfile镜像导入到Linux 大家好 我是寸铁👊 总结了一篇【Docker】Windows中打包dockerfile镜像导入到Linux✨ 喜欢的小伙伴可以点点关注 💝 前言 今天遇到一个新需求,如何将Windows中打包好的dockerfile镜像给迁移…...
数据结构之单链表实现(JAVA语言+C语言)
一、理论 1 单链表结构 2 增、删、查 、改思路 (增)直接添加放到最后即可。按顺序添加:找到要修改的节点的前一个节点,插入新节点()。(改)要修改的节点修改内容即可。(…...
AI可能让我们重获生活——如果我们不搞砸的话
前几天我把车停在客户办公楼的停车场,隔壁车位上有个女人坐在车里大声放着音乐。她注意到我在看她,摇下车窗说:"我一会儿就进去……只是想享受最后几分钟的自由时光!"这就是我们想要的生活方式吗?不…...
一次试样失败催生的技术革新:福尔蒂吹瓶专用ACR助剂逆向推演与流变拟合
那年夏天,一家饮料包装厂在调试新产线时遇到个棘手问题:吹瓶过程中频繁出现壁厚不均、肩部发白、甚至局部开裂——同一套模具、同一批PET切片、连温控参数都没动,就是反复试样失败。技术人员查了一周,最后把样本寄到了青岛福尔蒂新…...
2026知识付费SaaS避坑实测:主流平台对比,创客匠人为何成行业首选
SaaS平台实测对比:避开选型雷区,正规靠谱SaaS平台怎么挑?步入2026年,知识付费行业迈入精细化运营阶段,不管是个人知识博主、线下教培机构转型线上,还是企业布局知识变现业务,都离不开一款好用的…...
7个高效Avalonia项目管理技巧:从进度追踪到资源优化全指南
7个高效Avalonia项目管理技巧:从进度追踪到资源优化全指南 【免费下载链接】Avalonia AvaloniaUI/Avalonia: 是一个用于 .NET 平台的跨平台 UI 框架,支持 Windows、macOS 和 Linux。适合对 .NET 开发、跨平台开发以及想要使用现代的 UI 框架的开发者。 …...
CogVideoX-2b快速部署:3步完成AutoDL平台镜像启动配置
CogVideoX-2b快速部署:3步完成AutoDL平台镜像启动配置 想体验用文字直接生成电影级短视频的魔力吗?今天,我们来聊聊如何在AutoDL平台上,快速部署一个功能强大的本地化视频生成工具——CogVideoX-2b。这个工具基于智谱AI开源的Cog…...
Nano-Banana软萌拆拆屋入门指南:Comic Sans MS风格排版原理
Nano-Banana软萌拆拆屋入门指南:Comic Sans MS风格排版原理 1. 引言:当技术遇见软萌 你有没有想过,给冰冷的AI模型穿上可爱的外衣?今天要聊的Nano-Banana软萌拆拆屋,就是这样一个神奇的存在。它本质上是一个基于SDXL…...
全球爆火的龙虾杀入科研智能体赛道,字节跳动、微软以及英伟达等巨头也早已布局AI4Science领域
小罗碎碎念 如果说2020年至2023年是以AlphaFold为代表的模型在静态数据映射和结构预测上取得历史性突破的阶段,那么2025至2026年则标志着科学智能正式迈入“智能体(Agentic AI)”时代 。 在这一全新阶段,人工智能不再仅仅是被动…...
Linux服务器外网访问失败的5个常见坑点(附详细排查命令)
Linux服务器外网访问失败的5个系统性排查指南 刚部署完项目却发现外网无法访问?这可能是每个Linux运维新手都会遇到的"成人礼"。不同于零散的问题解决,本文将用系统化的排查思路,带你从底层网络原理到实操命令,彻底掌握…...
免费开源毕设:基于YOLO的道路缺陷检测系统
🛣️ 基于 YOLO 的道路缺陷检测系统 (Road Defect Detection System) 本项目是一个功能完整的道路缺陷(如路面坑洼 Pothole)智能检测系统。基于最新的 Ultralytics YOLO 系列模型构建,并提供了一个美观、易用的 Streamlit Web 交…...
收藏 | 产品经理/程序员入门大模型:AI知识库是RAG的“定海神针”!
一、 什么是 AI 知识库?它在 RAG 中扮演什么角色? 通俗理解:给大模型配一个“实时图书馆”如果把大模型比作一个参加考试的学生,那么普通的 LLM 是在“闭卷考试”,全凭记忆回答;而拥有 AI 知识库的 RAG 系统…...
