返回顶部
首页 > 资讯 > 前端开发 > JavaScript >JavaScript多级判定代码优化浅析
  • 519
分享到

JavaScript多级判定代码优化浅析

JS多级判定JS多级判定优化JS多级判定简化 2023-02-22 12:02:27 519人浏览 泡泡鱼
摘要

目录一、场景二、优化多级判定1.优化if-else结构2.二元运算符简化一、场景 业务代码里, 一次操作可能会前置多个判定, 我以前只是在函数的开头使用if语句去做这些事情, 虽然只

一、场景

业务代码里, 一次操作可能会前置多个判定, 我以前只是在函数的开头使用if语句去做这些事情, 虽然只是拦截一下不需要做else, 但是好多个判定堆在一起看着会有点…low, 而且, 如果这些东西堆在函数开头的话, 看起来就像这样:

xxx () {
  xxx
  xxx
  xxx
  xxx
  xxxxxxxxxxxxxxxxxxxxxxx
  xxxxxxxxxxxxxxxxxxxxxxxxxxx
  xxxxxxxxxxxxxxxxxxxxxxxxxxxxx
  xxxxxxxxxxxxxxxxxxxxxxxxxx
  xxxxxxxxxxxxxxxxxxxxxxxx
  xxxxxxxxxxxxx
}

像在竖大拇指 ), 咳…说回这种方法.

这其实是使用二元运算符 "&&"完成的一种简化写法, 可以理解为一种没有else的三元运算(因为我的逻辑里需要这种没有处理办法的写法), 我原本以为它需要void来驱动…的确可以在这种表达式外围包裹void, 我的确是这么做的, 整整一天.

void 运算符对给定的表达式进行求值,然后返回 undefined。

但其实根本没必要, void与否并不干扰执行.

Vue源码(此处仅指Vue2.6版, 我最近在看这个)里有大量的运用逻辑运算符来表达 “那么” 或者 “so” 的写法, 比如

src/core/vdom/patch.js中的这个函数.

function sameInputType (a, b) {
  if (a.tag !== 'input') return true
  let i
  const typeA = isDef(i = a.data) && isDef(i = i.attrs) && i.type
  const typeB = isDef(i = b.data) && isDef(i = i.attrs) && i.type
  return typeA === typeB || isTextInputType(typeA) && isTextInputType(typeB)
}

二、优化多级判定

最初我在使用这种改进后的if结构, 不再使用包裹式, 而是这种像闸口一样的结构.

当然特殊情况也还是要用if-else结构, 能优化就优化, 不能也不要强求.

1.优化if-else结构

就像这样:

if() {
  if() {

  } else if() {
  
  } else if() {

  }
} else if () {
  if() {

  } else if() {

  } else {

  }
}

再复杂一些, 再在内部加入各种逻辑, 就有些头疼了.

完全可以把每个条件单独分出一个if, 顺序不变, 比如以上可以优化为:

if () {
  if () {

  }
  if () {

  }
  if() {

  }
}
if () {
  if () {

  }
  if () {

  } else { // else一般没什么办法...

  }
}

else if里的"或"关系也可以单独拆一个 if 出来, 在看起来很复杂的情况下, 提升可读性.

图示一下的话, if-else-if结构就像深墙老院:

优化后的if结构更像是关隘:

有一个专有名词validation gatekeeping(验证守护), 即是描述这种验证结构.

但是一定注意判定条件的次序, 有些地方是必须用else if的, 否则会出现一个条件同时执行了多套处理方案的情况比如下面这个例子:

for (const key in newWorld) {
  if (key === 'webGLGroup') {
    this.worldList[oldWorldIndex][key]['children'] = this.worldList[oldWorldIndex][key]['children'].filter((ele) => { return ele.type !== 'Group' });
    this.worldList[oldWorldIndex][key]['children'].push(...newWorld[key]['children'].filter((ele) => { return ele.type === 'Group' }));
    for (const pro in newWorld[key]) pro !== 'children' && pro !== 'position' && pro !== 'rotation' && pro !== 'quaterNIOn' && pro !== 'scale' && (this.worldList[oldWorldIndex][key][pro] = newWorld[key][pro]);
  } else if (key !== 'frameInfo') this.worldList[oldWorldIndex][key] = newWorld[key];
}

这里把else if替换成if就会导致keyWEBglGroup时两条逻辑均会被执行.

所以原则还是能优化的优化.

2.二元运算符简化

嵌套else-if结构不太好用这种方式, 对于优化后的if结构用二元运算符重写, 个人觉得外层的大判定还是用if可读性会更好, 内部小判定用二元符简洁, 但其实你要是用二元运算符做嵌套判定结构的话, 层级问题会难以处理, 多个’&&'运算连在一起的时候javascript会将其解析为 仅最后一个&&为判定, 其他&&全表示 ‘和’ 关系.

当然如果你愿意在里面写函数的话是可以解决这个问题的, 用三元运算符做大判定也是可以的, 但是不好…

重写成如下:

if (10 > a > 0) {
  a > 1 && b > 3 && console.log('HelloWorld_1');
  (a > 2 && b > 4  ||  a === 100 && b > 10) && console.log('HelloWorld_2')
  // 这句可以再拆一个if出来的, 只是为了说明判定原理, 括号需要加
  // a大于2并b大于4 或 a等于100并b大于10 均可输出HelloWorld_2
}
if (a > 10) {
  // 可以结合三元运算符
  a === 12 ? c === 3 && console.log("a") : (b === 6 || c === 3 && a !== 15) && console.log("b")
  // 如何让前端同事追杀自己
  // 如果a等于12, 判定如果c等于3输出a
  // 如果a不等于12, 判定b等于6或c等于3并且a不为15,输出b
}

但是这种逻辑运算符我现在没有找到能在判定完成之后跳出执行的方法, 也就是说你可以用这个方法沿路做一些顺手的操作, 但是不能像在if里那样做完判定可以return跳出函数.

const a = 3 < 4 && 1
console.log(a)

然后, 额, 你可以用这种方法返回值

目的是提升可读性和简洁化代码, 如果一个很长的处理方案或者很长的条件就这样安插在二元运算符中间, 适得其反.

到此这篇关于JavaScript多级判定代码优化浅析的文章就介绍到这了,更多相关JS多级判定内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: JavaScript多级判定代码优化浅析

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

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

猜你喜欢
  • JavaScript多级判定代码优化浅析
    目录一、场景二、优化多级判定1.优化if-else结构2.二元运算符简化一、场景 业务代码里, 一次操作可能会前置多个判定, 我以前只是在函数的开头使用if语句去做这些事情, 虽然只...
    99+
    2023-02-22
    JS多级判定 JS多级判定优化 JS多级判定简化
  • JavaScript多级判定代码如何优化
    本篇内容介绍了“JavaScript多级判定代码如何优化”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、场景业务代码里, 一次操作可能会前...
    99+
    2023-07-05
  • JavaScript如何优化逻辑判断代码详解
    前言 我们日常使用到的逻辑判断语句有 if...else...、switch...case...、do...while...等。 在简单场景下,我们可能对这些语法的性能没有什么感觉,...
    99+
    2024-04-02
  • JavaScript代码优化技巧实例分析
    这篇文章主要介绍“JavaScript代码优化技巧实例分析”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“JavaScript代码优化技巧实例分析”文章能帮助大家解决...
    99+
    2024-04-02
  • JavaScript避免嵌套代码浅析
    目录前言一、何为嵌套代码二、避免嵌套1.提炼抽取2.反转排列前言 看过不少过度嵌套的代码, 我真正意识到问题的严重性是刚入职那会, 我在一个老项目里看到了40个连续的else if,...
    99+
    2023-02-22
    JS避免嵌套代码 JS嵌套代码 JS代码不嵌套
  • spring初始化源码代码浅析
    目录前言1、refresh()简介2、关键代码跟踪2.1、obtainFreshBeanFactory()代码分析2.2、invokeBeanFactoryPostProcessor...
    99+
    2023-05-18
    spring初始化源码 spring初始化代码 spring 初始化
  • Javascript前端优化代码
    目录if 判断的优化1、最简单的方法:if 判断2、好一点的方法:Switch3、更优的方法: 策略模式includes 的优化for 循环数组去重1、最传统的方法:利用数组的ind...
    99+
    2024-04-02
  • JavaScript代码优化的技巧实例分析
    本篇内容主要讲解“JavaScript代码优化的技巧实例分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript代码优化的技巧实例分析”吧!写在前面想要做到JavaScript的代...
    99+
    2023-07-02
  • 深入浅析Java中多线程优先级
    这篇文章给大家介绍深入浅析Java中多线程优先级,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Java 多线程优先级实例详解线程的优先级将该线程的重要性传递给调度器。尽管CPU处理现有线程集的顺序是不确定的,但是调度器...
    99+
    2023-05-31
    java 多线程 优先级
  • python 代码检查,实现行级代码优化
        有时候运行一个python程序,它需要运行很长时间。你或许想提升该程序的运行效率。那该怎么做那?     首先需要你要找到该程序瓶颈在哪里~   比如,哪个函数的运行花费时间比较长? 哪个函数占用内存比较多,是否需要优化对内存的使用...
    99+
    2023-01-31
    代码 python
  • 怎么引入javascript代码?方式浅析
    近年来,随着JavaScript技术的高速发展,越来越多的开发者开始在自己的项目中使用这种语言。在使用JavaScript时,引入方式是非常重要的一环。但是,事实上有一些场景下并不适合采用JavaScript的传统引入方式,即<scr...
    99+
    2023-05-14
  • JavaScript 代码优化终极指南:成为 JavaScript 优化大师
    JavaScript 是一种灵活且强大的语言,但如果编写不当,它可能会变得很慢。通过遵循一些简单的优化技巧,您可以显著提高 JavaScript 代码的速度和性能。 1. 使用严格模式 严格模式是一种 JavaScript 语法,可以帮助...
    99+
    2024-02-27
    JavaScript、代码优化、性能提升、代码压缩、代码规范
  • 如何优化Javascript前端代码
    这期内容当中小编将会给大家带来有关如何优化Javascript前端代码,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。JavaScript的作用是什么1、能够嵌入动态文本于HTML页面。2、对浏览器事件做出...
    99+
    2023-06-14
  • JavaScript 代码优化实战教程:手把手教你优化你的代码
    1. 使用严格模式 严格模式是一种有助于消除 JavaScript 中一些常见错误的模式。它可以防止代码中的某些操作,例如: 在未声明的情况下使用变量 对只读属性进行赋值 删除未定义的属性 使用 eval() 函数 使用 with 语...
    99+
    2024-02-27
    JavaScript 代码优化、网站性能、用户体验
  • JavaScript代码优化技巧有哪些
    这篇文章主要介绍“JavaScript代码优化技巧有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“JavaScript代码优化技巧有哪些”文章能帮助大家解决问题。1. 使用扩展运算符解构对象和数...
    99+
    2023-07-05
  • python代码优化案例分析
    第一版举例:def displayNumType(num):     print num,"is",     if type(num)==type(0):         print 'an interger'     elif type(...
    99+
    2023-01-31
    案例分析 代码 python
  • JavaScript 代码优化技巧:让你的代码飞起来!
    一、选择合适的数据结构 数据结构的选择对 JavaScript 代码的性能有很大的影响。不同的数据结构适合不同的应用场景。常用的数据结构包括数组、链表、哈希表、栈和队列等。 数组:数组是一种有序的数据结构,可以快速访问元素。适合存储...
    99+
    2024-02-27
    JavaScript 代码优化、性能优化、数据结构、算法、代码结构、浏览器特性
  • JavaScript代码简化的示例分析
    这篇文章主要为大家展示了“JavaScript代码简化的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JavaScript代码简化的示例分析”这篇文章吧...
    99+
    2024-04-02
  • PHP代码优化的示例分析
    这篇文章主要介绍了PHP代码优化的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一小段“劣质”的PHP代码优化的过程,请仔细体会优化...
    99+
    2024-04-02
  • 浅谈Java多线程的优点及代码示例
    尽管面临很多挑战,多线程有一些优点使得它一直被使用。这些优点是:资源利用率更好程序设计在某些情况下更简单程序响应更快资源利用率更好想象一下,一个应用程序需要从本地文件系统中读取和处理文件的情景。比方说,从磁盘读取一个文件需要5秒,处理一个文...
    99+
    2023-05-30
    java 多线程 ava
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作