iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >如何实现JavaScript if分支优化
  • 285
分享到

如何实现JavaScript if分支优化

2023-07-05 11:07:20 285人浏览 独家记忆
摘要

今天小编给大家分享一下如何实现javascript if分支优化的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。最近在网上冲浪

今天小编给大家分享一下如何实现javascript if分支优化的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

最近在网上冲浪时看到了这样一段代码:

function getUserDescribe(name) {    if (name === "小刘") {        console.log("刘哥哥");    } else if (name === "小红") {        console.log("小红妹妹");    } else if (name === "陈龙") {        console.log("大师");    } else if (name === "李龙") {        console.log("师傅");    } else if (name === "大鹏") {        console.log("恶人");    } else {        console.log("此人比较神秘!");    }}

咋一看没感觉有什么异常,但如果有1000个判断条件,按照这种写法难不成要写1000个 if 分支?

如果写了大量的 if 分支,并且可能还具有分支套分支,可以想象到整个代码的可读性和可维护都会大大降低,这在实际开发中,确实是一个比较头疼的问题,那有没有什么办法能够即实现需求又能避免这些问题呢?

1️⃣ 简单分支优化

这就涉及到分支优化,让我们转换思维,去优化一下上面的代码结构:

function getUserDescribe(name) {    const describeForNameMap = {        小刘: () => console.log("刘哥哥"),        小红: () => console.log("小红妹妹"),        陈龙: () => console.log("大师"),        李龙: () => console.log("师傅"),        大鹏: () => console.log("恶人"),    };    describeForNameMap[name] ? describeForNameMap[name]() : console.log("此人比较神秘!");}

问题代码中的判断都是简单的相等判断,那么我们就可以将这些判断条件作为一个属性写到对象describeForNameMap 中去,这些属性对应的值就是条件成立后的处理函数。

之后我们就只需通过getUserDescribe函数接收到的参数去获取describeForNameMap对象中对应的值,如果该值存在就运行该值(因为值是一个函数)。

这样一来原本的 if 分支判断就转换成了简单的key value对应值,条件与处理函数一一对应,一目了然。

2️⃣ 复杂分支优化

那如果我们的 if 分支中的判断条件不只是简单的相等判断,还具有一些需要计算的表达式时,我们该怎么办呢?(如下所示)

function getUserDescribe(name) {    if (name.length > 3) {        console.log("名字太长");    } else if (name.length < 2) {        console.log("名字太短");    } else if (name[0] === "陈") {        console.log("小陈");    } else if (name[0] === "李" && name !== "李鹏") {        console.log("小李");    } else if (name === "李鹏") {        console.log("管理员");    } else {        console.log("此人比较神秘!");    }}

对于这种结构的代码就不能引入对象来进行分支优化了,我们可以引入二维数组来进行分支优化:

function getUserDescribe(name) {    const describeForNameMap = [        [            (name) => name.length > 3, // 判断条件            () => console.log("名字太长") // 执行函数        ],        [            (name) => name.length < 2,             () => console.log("名字太短")        ],        [            (name) => name[0] === "陈",             () => console.log("小陈")        ],        [            (name) => name === "大鹏",             () => console.log("管理员")        ],        [            (name) => name[0] === "李" && name !== "李鹏",            () => console.log("小李"),        ],    ];    // 获取符合条件的子数组    const getDescribe = describeForNameMap.find((item) => item[0](name));    // 子数组存在则运行子数组中的第二个元素(执行函数)    getDescribe ? getDescribe[1]() : console.log("此人比较神秘!");}

上面我们定义了一个describeForNameMap数组,数组内的每一个元素代表一个判断条件与其执行函数的集合(也是一个数组),之后我们通过数组的find方法查找describeForNameMap数组中符合判断条件的子数组即可。

3️⃣ 抽离分支

上面例子中我们定义的这个describeForNameMap对象是一个独立的结构,我们完全可以将它抽离出去:

const describeForNameMap = {    小刘: () => console.log("刘哥哥"),    小红: () => console.log("小红妹妹"),    陈龙: () => console.log("大师"),    李龙: () => console.log("师傅"),    大鹏: () => console.log("恶人"),};function getUserDescribe(name) {    describeForNameMap[name] ? describeForNameMap[name]() : console.log("此人比较神秘!");}
const describeForNameMap = [    [        (name) => name.length > 3, // 判断条件        () => console.log("名字太长") // 执行函数    ],    [        (name) => name.length < 2,         () => console.log("名字太短")    ],    [        (name) => name[0] === "陈",         () => console.log("小陈")    ],    [        (name) => name === "大鹏",         () => console.log("管理员")    ],    [        (name) => name[0] === "李" && name !== "李鹏",        () => console.log("小李"),    ],];    function getUserDescribe(name) {    // 获取符合条件的子数组    const getDescribe = describeForNameMap.find((item) => item[0](name));    // 子数组存在则运行子数组中的第二个元素(执行函数)    getDescribe ? getDescribe[1]() : console.log("此人比较神秘!");}

通过模块化的开发也可以将这个map对象写进一个单独的js文件,之后在需要使用的地方导入即可。

4️⃣ 争议

这样一来整个getUserDescribe函数就变得非常简洁,有的同学可能会问这有什么用呢?这不是更加麻烦了吗?如果真的嫌if else不好看,那我就使用if return不用else就好了:

function getUserDescribe(name) {    if (name === "小刘") {        console.log("刘哥哥");        return;    }    if (name === "小红") {        console.log("小红妹妹");        return;    }    if (name === "陈龙") {        console.log("大师");        return;    }    if (name === "李龙") {        console.log("师傅");        return;    }    if (name === "大鹏") {        console.log("恶人");        return;    }    console.log("此人比较神秘!");}

试想一下,如果你getUserDescribe函数中有1000个判断分支,并且还具有大量的根据判断结果来执行的处理代码,并且getUserDescribe函数会返回这个处理后的判断结果的值。

这时getUserDescribe函数的重点在于对判断结果的处理,而不在于这个结果是通过什么分支获取的,例如:

function getUserDescribe(name) {    let str; // 存储判断结果    if (name.length > 3) {        str = "名字太长";    } else if (name.length < 2) {        str = "名字太短";    } else if (name[0] === "陈") {        str = "小陈";    } else if (name[0] === "李" && name !== "李鹏") {        str = "小李";    } else if (name === "李鹏") {        str = "管理员";    } else {        str = "此人比较神秘!";    }    // 对判断结果str的一些处理    // ......    console.log(str);    return str;}

如果你不进行分支优化,getUserDescribe函数就会被大量的 if 分支抢占空间,使得getUserDescribe函数的重点迷失(getUserDescribe函数重点在于对判断结果的处理,而不在于这个结果是通过什么分支获取的),这时你再看一下我们优化后的代码:

const describeForNameMap = [    [(name) => name.length > 3, () => "名字太长"],    [(name) => name.length < 2, () => "名字太短"],    [(name) => name[0] === "陈", () => "小陈"],    [(name) => name === "大鹏", () => "管理员"],    [(name) => name[0] === "李" && name !== "李鹏", () => "小李"],];function getUserDescribe(name) {    let str; // 存储判断结果    const getDescribe = describeForNameMap.find((item) => item[0](name));    if (getDescribe) {        str = getDescribe[1]();    } else {        str = "此人比较神秘!";    }    // 对判断结果str的一些处理    // ......    console.log(str);    return str;}

查看优化后的getUserDescribe函数我们能够知道,它从describeForNameMap获取了一个值赋值给了strdescribeForNameMap是如何返回值的我们并不关心),之后对str作了一些处理。这就突出了getUserDescribe函数的重点(对判断结果str进行处理)。

在这个例子中describeForNameMap子数组的第二个元素完全可以直接使用一个值:[(name) => name.length > 3,  "名字太长"],但为了整体代码的可扩展性,推荐还是使用函数,因为函数可以接收参数,方便应对之后更复杂的场景。

以上就是“如何实现JavaScript if分支优化”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网精选频道。

--结束END--

本文标题: 如何实现JavaScript if分支优化

本文链接: https://www.lsjlt.com/news/351650.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何实现JavaScript if分支优化
    今天小编给大家分享一下如何实现JavaScript if分支优化的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。最近在网上冲浪...
    99+
    2023-07-05
  • 一文教你实现JavaScript if分支优化
    4️⃣ 争议这样一来整个getUserDescribe函数就变得非常简洁,有的同学可能会问这有什么用呢?这不是更加麻烦了吗?如果真的嫌if else不好看,那我就使用if return不用else就好了:function getUserDe...
    99+
    2023-05-14
    if-else javascript
  • JavaScript怎么实现分支优化
    这篇“JavaScript怎么实现分支优化”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“JavaScript怎么实现分支优化...
    99+
    2023-07-04
  • 一文教你JavaScript如何实现分支优化
    以上就是一文教你JavaScript如何实现分支优化的详细内容,更多请关注编程网其它相关文章!...
    99+
    2022-11-22
    javascript
  • JavaScript如何简化if ... else
    小编给大家分享一下JavaScript如何简化if ... else,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!简化 if ... elseif...else太...
    99+
    2023-06-27
  • MySQL如何实现分表优化
    这篇文章将为大家详细讲解有关MySQL如何实现分表优化,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。   这里的分表逻辑是根据t_group表的user_nam...
    99+
    2024-04-02
  • JavaScript如何简化分支条件语句
    这篇文章主要介绍了JavaScript如何简化分支条件语句,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。简化分支条件语句又是你,if...else if...else!跟sw...
    99+
    2023-06-27
  • java多层if嵌套如何优化
    在Java中,多层的if嵌套可以通过以下方式进行优化:1. 使用逻辑运算符来简化条件判断:可以使用逻辑与(&&)和逻辑或(||)运算...
    99+
    2023-09-13
    java
  • java中如何优化大量if...else...
    本文小编为大家详细介绍“java中如何优化大量if...else...”,内容详细,步骤清晰,细节处理妥当,希望这篇“java中如何优化大量if...else...”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。策...
    99+
    2023-07-05
  • 如何在java中使用if分支语句
    如何在java中使用if分支语句?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Java的特点有哪些Java的特点有哪些1.Java语言作为静态面向对象编程语言的代表,实现了...
    99+
    2023-06-14
  • 如何实现SQL优化
    这篇文章主要介绍“如何实现SQL优化”,在日常操作中,相信很多人在如何实现SQL优化问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何实现SQL优化”的疑惑有所帮助!接下来,...
    99+
    2024-04-02
  • 如何理解if-else涉及到分支预测
    这篇文章主要讲解了“如何理解if-else涉及到分支预测”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何理解if-else涉及到分支预测”吧!首先看一段经...
    99+
    2024-04-02
  • 分享如何实现javascript
    在现代网站开发中,JavaScript 已经成为了不可或缺的一部分,可以实现交互效果、验证表单、动态加载内容等众多操作。不过,为了让 JavaScript 能够实现这些功能,我们需要对其进行一定的开发前准备和编码技巧。本文将分享如何实现 J...
    99+
    2023-05-17
  • Golang 技术性能优化中如何实现分布式性能优化?
    如何实现 golang 分布式性能优化?并发编程: 利用 goroutine 并行执行任务。分布式锁: 使用互斥锁防止并发操作导致数据不一致。分布式缓存: 使用 memcached 减少...
    99+
    2024-05-12
    golang 性能优化 git
  • 如何优化Java代码中大量的if/else
    这篇文章主要介绍了如何优化Java代码中大量的if/else的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇如何优化Java代码中大量的if/else文章都会有所收获,下面我们一起来看看吧。观点一(灵剑)前期迭代...
    99+
    2023-07-05
  • 如何实现MySQL底层优化:执行计划分析和优化技巧
    实现MySQL底层优化:执行计划分析和优化技巧引言在数据库应用程序的开发和运维中,针对MySQL数据库进行底层优化是非常重要的。MySQL执行计划分析和优化技巧可以帮助开发人员和运维人员提升数据库的性能和稳定性,本文将介绍如何实现MySQL...
    99+
    2023-11-08
    优化技巧 执行计划 底层优化 MySQL优化关键词:
  • JavaScript代码优化技巧实例分析
    这篇文章主要介绍“JavaScript代码优化技巧实例分析”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“JavaScript代码优化技巧实例分析”文章能帮助大家解决...
    99+
    2024-04-02
  • 详解JavaScript中if语句优化和部分语法糖小技巧推荐
    目录前言if else 基本使用简化if判断和优化代码单行if else使用&& || 优化使用三目运算符优化合并if使用includes 或者indexof使用sw...
    99+
    2024-04-02
  • MySQL性能优化如何实现
    这篇文章将为大家详细讲解有关MySQL性能优化如何实现,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一般来说,要保证数据库的效率,要做好以下四个方面的工作:数据库表设计S...
    99+
    2024-04-02
  • python如何实现循环优化
    这篇文章给大家分享的是有关python如何实现循环优化的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。循环优化# 不推荐写法。代码耗时:6.7秒def computeSum(size: ...
    99+
    2023-06-27
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作