【JS代码优化一】分支优化篇

简介: 【JS代码优化一】分支优化篇

序:如何让代码看起来更优雅?代码是由文字堆叠起来的可以被机器执行的程序。它记载着相关信息(状态)、表达相关的情绪(函数),所以如何能够写出简洁、优雅、健壮、可维护性强的程序至关重要。本系列笔记的目的,就是带着大家如何实现更有效、更优雅的编程。笔记涵盖:运算符、流程语句、设计模式、ES6 新增方法等多个方面。

数字化管理平台

Vue3+Vite+VueRouter+Pinia+Axios+ElementPlus教程

权限系统-商城

个人博客地址

1. 逻辑或运算符 ||

逻辑或运算符,也叫短路运算符。当 || 运算符左边的值为 true 时,则返回左边表达式的值,反之则返回右边表达式的值。如下:

true || false   // true
false || true   // true
10 > 20 || "Hello"  // "Hello"
"" || 0   // 0
undefined || null   // null

上面代码是逻辑或最常用的场景,其实基于上面的场景,可以来优化大家经常写的 if…else 代码,如下:

let result
if (a) {
  result = a
} else {
  result = b
}

很简单的一段代码,但是使用短路运算符要简洁的多,如下:

let result = a || b

2. 三元运算符 ? :

提到 if…else 优化,就不得不说一下三元运算符了。这个运算符在替换条件语句的时候也是很好用的。但是注意不要嵌套太多层哦!毕竟嵌套多了,可读性就不强了,也就背离了我们代码优化的目的。

语法格式:

条件表达式 ? 条件表达式成立的值 : 条件表达式不成立的值

这样上面的 if 语句,使用三元运算符表示如下:

let result = a ? a : b

当然,写到这里,见多识广的你可能会想到上面的语句还能再一步优化,这里先卖个关子,大家可以在后面的案例中查找彩蛋。

三元表达式在诸如:条件判断、条件赋值、递归等场景应用也是比较多的。如下,实现一个累加函数:

使用条件语句实现

let sum = 0;
function increment (n) {
  sum += n
  if (n === 1) 
    return sum
  else 
    return increment(n - 1)
}

使用三元运算符实现

let sum = 0;
function increment (n) {
  sum += n
  return n >= 2 ? increment(n - 1) : sum
}

3. 对象/数组配置

对于条件复杂的多重判断,三元运算符可读性不强,条件语句和选择语句可以实现,但是写起来很麻烦,代码变得很臃肿。如下:

条件语句实现:

let dayNum = 1
let getWeekDay = (dayNum) => {
  if (dayNum === 7) {
      return "星期日"
  } else if (dayNum === 1) {
      return "星期一"
  } else if (dayNum === 2) {
      return "星期二"
  } else if (dayNum === 3) {
      return "星期三"
  } else if (dayNum === 4) {
      return "星期四"
  } else if (dayNum === 5) {
      return "星期五"
  } else if (dayNum === 6) {
      return "星期六"
  } else {
      return "不是合法的值"
  }
}

选择语句实现:

let result;
switch (dayNum) {
    case 0: 
        result = "星期日"
        break
    case 1: 
        result = "星期一"
        break
    case 2: 
        result = "星期二"
        break
    case 3: 
        result = "星期三"
        break
    case 4: 
        result = "星期四"
        break
    case 5: 
        result = "星期五"
        break
    case 6: 
        result = "星期六"
        break
    default:
        result = "不是合法的值"
        break
}
return result;

看到这里,你应该已经不想看了,不禁吐槽:这也太麻烦了吧!是的,所以我们想办法优化他吧,比方把相关的数据封装到数组或者对象中,然后取对应的值呢?

数组方式实现:

let days = ["星期一", "星期二", "星期三", "星期四", "星期五", "星期六", "星期日"]
let result = days[dayNum] ?? "不是合法的值"

对象方式实现:

let days = {
    0: "星期日",
    1: "星期一",
    2: "星期二",
    3: "星期三",
    4: "星期四",
    5: "星期五",
    6: "星期六",
}
let result = days[dayNum] ?? "不是合法的值"

这样的代码,在你看来是不是有一种“神清气爽”的感觉。ES6 中新增 Map 对象,我们同样可以使用 Map 来实现上面的功能,原理都是一样的。

let days = new Map([
    [0, "星期日"],
    [1, "星期一"],
    [2, "星期二"],
    [3, "星期三"],
    [4, "星期四"],
    [5, "星期五"],
    [6, "星期六"]
])
let result = days.get(dayNum) || "不是合法的值"

4. 复杂条件分支优化

上面所列举的都是一些比较简单直接的判断条件,如果判断条件过于复杂,那么我们应该如何去处理呢?先看下面这段改造代码:

let days = {
   0: () => "星期日",
   1: () => "星期一",
   2: () => "星期二",
   3: () => "星期三",
   4: () => "星期四",
   5: () => "星期五",
   6: () => "星期六",
}
let result = days[dayNum] ? days[dayNum]() : "不是合法的值"

看过上面的代码,你可能会说这不还是 key-value 形式吗,无非就是多了一步,需要执行函数才能获得对应的值。没错,但是这样的好处是,你可以在对应的函数中执行任何你想实现的逻辑,相对更加灵活一些。

那么,回过头了,我们继续说复杂条件分支的优化问题,如下:

let score = 98;
let getResult = (score) => {
    if (score <= 100 && score >= 90) {
        return "优秀"
    } else if (score < 90 && score >= 80) {
        return "良好"
    } else if (score < 80 && score >= 70) {
        return "中等"
    } else if (score < 70 && score >= 60) {
        return "及格"
    } else if (score < 60 && score >= 0) {
        return "不及格"
    } else {
        return "非法字符"
    }
}

很明显,上面判断的条件表达式不再是简单的等值判断了,像这种情况,我们依旧可以按照上面的思想进行优化改造。可以考虑使用二维数组实现。

二维数组方式:

let scores = [
    [(score) => score <= 100 && score >= 90, () => "优秀"],
    [(score) => score <= 90 && score >= 80, () => "良好"],
    [(score) => score <= 80 && score >= 70, () => "中等"],
    [(score) => score <= 70 && score >= 60, () => "及格"],
    [(score) => score <= 60 && score >= 0, () => "不及格"]
]
let getResult = (score) => {
    // 判断符合条件的子数组
    let obj = scores.find(v => v[0](score))
    // 子数组存在,则运行数组中第二个函数元素,否则返回其它信息
    let result = obj ? obj[1]() : "非法字符"
    return result;
}

这里注重的是最终得到的结果,而不是获得结果的过程。当今硬件性能过剩下情况下,我们通过这种更加优雅、简洁、可维护性的方式来获取最终想要的结果,显然是更可取的。

你要记住:优雅永不过时,浪漫至死不渝。

好了,到这里《JS代码优化一》分享就已经结束了,如果感觉还不错记得点赞收藏。你还知道哪些代码优化的方案呢?那就写出来把。


相关文章
|
14天前
|
缓存 前端开发 JavaScript
优化CSS和JavaScript加载
优化CSS和JavaScript加载
|
18天前
|
缓存 JavaScript 前端开发
介绍一下 JavaScript 中数组方法的常见优化技巧
通过合理运用这些优化技巧,可以提高 JavaScript 中数组方法的执行效率,提升代码的整体性能。在实际开发中,需要根据具体的业务场景和数据特点选择合适的优化方法。
24 6
|
16天前
|
缓存 前端开发 JavaScript
优化CSS和JavaScript加载
Next.js和Nuxt.js在优化CSS和JavaScript加载方面提供了多种策略和工具。Next.js通过代码拆分、图片优化和特定的CSS/JavaScript优化措施提升性能;Nuxt.js则通过代码分割、懒加载、预渲染静态页面、Webpack配置和服务端缓存来实现优化。两者均能有效提高应用性能。
|
24天前
|
JSON 监控 JavaScript
Node.js-API 限流与日志优化
Node.js-API 限流与日志优化
|
2月前
|
存储 JavaScript 前端开发
JavaScript垃圾回收机制与优化
【10月更文挑战第21】JavaScript垃圾回收机制与优化
32 5
|
3月前
|
缓存 JavaScript 中间件
优化Express.js应用程序性能:缓存策略、请求压缩和路由匹配
在开发Express.js应用时,采用合理的缓存策略、请求压缩及优化路由匹配可大幅提升性能。本文介绍如何利用`express.static`实现缓存、`compression`中间件压缩响应数据,并通过精确匹配、模块化路由及参数化路由提高路由处理效率,从而打造高效应用。
171 10
|
3月前
|
存储 缓存 JavaScript
JavaScript 中数组方法的常见优化技巧
JavaScript 中数组方法的常见优化技巧
|
4月前
|
机器学习/深度学习 存储 前端开发
实战揭秘:如何借助TensorFlow.js的强大力量,轻松将高效能的机器学习模型无缝集成到Web浏览器中,从而打造智能化的前端应用并优化用户体验
【8月更文挑战第31天】将机器学习模型集成到Web应用中,可让用户在浏览器内体验智能化功能。TensorFlow.js作为在客户端浏览器中运行的库,提供了强大支持。本文通过问答形式详细介绍如何使用TensorFlow.js将机器学习模型带入Web浏览器,并通过具体示例代码展示最佳实践。首先,需在HTML文件中引入TensorFlow.js库;接着,可通过加载预训练模型如MobileNet实现图像分类;然后,编写代码处理图像识别并显示结果;此外,还介绍了如何训练自定义模型及优化模型性能的方法,包括模型量化、剪枝和压缩等。
55 1
|
4月前
|
JSON JavaScript 前端开发
震惊!JS如何悄无声息追踪你的每一步?揭秘页面访问与关闭的超级上报大法,让数据说话,优化体验不再难!
【8月更文挑战第4天】在Web开发中,跟踪用户行为对提升体验与留存至关重要。本文以在线学习平台为例,介绍如何用JavaScript监听页面访问及关闭,并上报数据。通过`window.onload`监测页面加载,记录用户访问;利用`navigator.sendBeacon`在用户离开时发送少量数据至服务器,无需担心请求失败。需注意隐私合规、性能影响及浏览器兼容性。此技术有助于深入理解用户行为,为产品迭代提供依据。
165 8
|
4月前
|
C# 开发者 测试技术
震惊!Xamarin 竟能如此构建跨平台应用程序,代码共享、界面设计与性能优化全攻略大揭秘!
【8月更文挑战第31天】在移动应用开发领域,跨平台工具日益受到青睐。Xamarin 是一款强大的工具,支持使用 C# 开发适用于 iOS、Android 和 Windows 的应用。通过安装 Visual Studio 或 Visual Studio for Mac,并创建 Xamarin 项目,开发者可以利用丰富的功能和工具进行开发。Xamarin 的主要优势在于代码共享,能够显著提高开发效率。
80 0