iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >JavaScript如何避免嵌套代码
  • 761
分享到

JavaScript如何避免嵌套代码

2023-07-05 04:07:36 761人浏览 安东尼
摘要

本篇内容介绍了“javascript如何避免嵌套代码”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、何为嵌套代码嵌套代码是在函数内部添加更

本篇内容介绍了“javascript如何避免嵌套代码”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

一、何为嵌套代码

嵌套代码是在函数内部添加更深层级的代码块, 放在javascript里, 常用的嵌套手段都包含符号’{‘, 那么对于一个代码块, 刨除平级的情况, 其内部的’{'越多就说明这个代码块的嵌套深度越大.

也就是: 禁止套娃.

对于以下代码, 它的嵌套深度为1:

function fun1 () {  console.log(1);}

而如果在内部加上if语句, 其深度将变为2:

function fun1 () {  if (true) {    console.log(1);  }}

而如果再加一个循环进去, 深度将变为3:

function fun1 () {  if (true) {    for (let i = 0; i < 5; i++) {      console.log(1);    }  } else {    console.log(2);  }}

好的各位, 我最多最多就到这了, 再套下去我就要开始觉得恶心了.在这里可能没有那么直观, 而这段代码放在编辑器里, console.log前面已经有三道竖线了, 光是tab提行就已经开始不舒服了.

在三层嵌套以上, 你所做的一切就不再是一套单一的算法, 这已经开始逐渐演变为多个算法的组合了, 是可以做一些封装抽离而最好不要就这样混写在一起.

实战中三层嵌套绝对连半数以下的计算都处理不了, 那如果还有逻辑没编写呢.

二、避免嵌套

1.提炼抽取

提炼(Extraction), 我一般管这叫抽离, 当然, 不一定要抽到外面, 只要能维持嵌套深度处于稳定的水平就好(不过函数内实在不能在消减嵌套深度那还是抽到外面形成另外一个函数吧).

比如这段嵌套:

function fun1() {  const arr = [1, 2, 3, 4]  if (arr.length = 4) {    arr.forEach((ele) => {      if (a === 4) {        console.log(4);      }    });  }}fun1();

可以改为这样:

function fun1() {  const arr = [1, 2, 3, 4]  const xxx = (a) => {    if (a === 4) {      console.log(4);    }  }  if (arr.length = 4) {    arr.forEach(xxx);  }}fun1();

嵌套深度由4减小为3.

原理十分明了, 就好像在原生环境获取DOM, 有的人喜欢这样:

function change() {  document.querySelector("#scar").style.display = 'none';}

有的人喜欢:

function change() {  const scar = document.querySelector("#scar");  scar.style.display = 'none';}

抽离提炼就类似于将前者转化为了后者.

封装axiOS也是一样的道理(不过那更多还是为了避免接口变动导致的被动局面).

2.反转排列

反转(Inversion), 对于判定语句, 把正面条件排在负面条件前通常会需要更多的判定, 所以改为优先处理负面条件.

先把正面条件放前面:

function justice(e) {  if(e.length > 5) {    for(let i = 0; i < e.length; i++) {      console.log(e);    }  } else if (e.length === 2){    return 2;  } else {    return false  }}

但是如果先进行负面条件判定:

function justice(e) {  if(e.length === 2) {    return 2;  } else if (e.length < 5) { // 这里也可以另起一个if, 不过这样可以节约一行 )    return false;  }   for(let i = 0; i < e.length; i++) {    console.log(e);  }}

可以看到现在深度层级由3减小到2.

这种优化方法需要先把少数, 需要特殊处理的情况在前面解决完及时退出, 剩下的多数情况就可以不放在判定语句中.

而在这个过程中, 需要把最特殊, 且不将其他特殊情况包含在内的情况写在前面, 越特殊, 越提前处理, 此处e.length === 2为最特殊, 而e.length < 5这个特殊情况将e.length === 2包含在内, 所以应当第二个处理.

我在前面也写过这种做法, 将判定嵌套改为平次的卫语句, 称作validation gatekepping, 感兴趣的话可以去看这篇:

JavaScript多级判定代码优化浅析

不过还可以在平次判定这个基础上使用这个技巧, 我们把负面情况放在靠前的平次判定处理, 如果处理中途出现过多嵌套, 那就提炼抽离, 把正面条件放最后:

function justice(e) {  if(e.length === 2) {    return 2;  }  if(e.length === 3) {    return 3;  }  if (e.length < 5) {    return false;  }   for(let i = 0; i < e.length; i++) {    console.log(e);  }}

截取最近项目里的代码作为例子, 现在有两个world, 一个新一个旧, 如果需要让旧world的视图更新, 那么需要将新world的world.webGLGroup.children内的元素部分替换, 其他除world.frameInfo外也要全替换.

async changeWorld(oldFrame, newWorld) {  for (const key in newWorld) {    if (key === 'frameInfo') {    } else if (key === 'WEBglGroup') {      for (const pro in newWorld[key]) {        if (pro === 'children') {          this.worldList[oldWorldIndex][key][pro] = this.worldList[oldWorldIndex][key][pro].filter((ele) => { return ele.type !== 'Group' });          this.worldList[oldWorldIndex][key][pro].push(...newWorld[key][pro].filter((ele) => { return ele.type === 'Group' }));        } else {          this.worldList[oldWorldIndex][key][pro] = newWorld[key][pro];        }      }    } else {      this.worldList[oldWorldIndex][key] = newWorld[key];    }  }}

以上是初版, 现在用Extraction提炼和Inversion反转去尝试降低嵌套深度:

先把world.webglGroup.children局部替换的代码提炼为replace,

已知world.frameInfo不需要替换, 那么正常的负面条件写法应当为key === 'frameInfo', 但即便如此key === 'frameInfo'key === 'webglGroup'也是必须用else if处理的, 如果改成平次if又不能终止执行, 那么这两个特殊条件在一轮循环中都会被执行.

本着要把正面条件处理方案写最后的原则, 直接在最后一个特殊条件不满足(按照上文所述写法, 最后一个特殊条件不满足说明前面所列特殊条件均不满足)时执行正面条件处理方案.

else if (key !== 'frameInfo') {  this.worldList[oldWorldIndex][key] = newWorld[key];}
async changeWorld(oldFrame, newWorld) {  let oldWorldIndex = this.worldList.findIndex((w) => w.frameInfo.frame === oldFrame);  const replace = () => {    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 key in newWorld) {    if (key === 'webglGroup') {      replace(key);    } else if (key !== 'frameInfo') {      this.worldList[oldWorldIndex][key] = newWorld[key];    }  }  return this.worldList[oldWorldIndex];}

只是判定需求不同罢了.上面这种写法是在所有负面条件不满足时执行正面条件处理方案.前面反转的例子是在任意负面条件不满足时结束执行.但遵循两种优化手段的原则都可以实施优化.

“JavaScript如何避免嵌套代码”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: JavaScript如何避免嵌套代码

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

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

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

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

下载Word文档
猜你喜欢
  • JavaScript如何避免嵌套代码
    本篇内容介绍了“JavaScript如何避免嵌套代码”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、何为嵌套代码嵌套代码是在函数内部添加更...
    99+
    2023-07-05
  • JavaScript避免嵌套代码浅析
    目录前言一、何为嵌套代码二、避免嵌套1.提炼抽取2.反转排列前言 看过不少过度嵌套的代码, 我真正意识到问题的严重性是刚入职那会, 我在一个老项目里看到了40个连续的else if,...
    99+
    2023-02-22
    JS避免嵌套代码 JS嵌套代码 JS代码不嵌套
  • JavaScript如何尽量避免if else嵌套
    小编给大家分享一下JavaScript如何尽量避免if else嵌套,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!尽量避免if else 嵌套例如const&nb...
    99+
    2023-06-27
  • Java中避免写嵌套if样式的代码详解
    前言Optional的代码相对更加简洁,当代码量较大时,我们很容易忘记进行null判定,但是使用Optional类则会避免这类问题。下面这是一个嵌套的 if 判断,业务逻辑是从 httpRequst 中获取 X-Auth-Token 的值。...
    99+
    2023-05-31
    java if嵌套 ava
  • VUE 嵌套路由的陷阱与回避:避免常见错误
    陷阱:如果父路由和子路由具有相同的名称,将导致路由冲突,无法正确解析请求。 回避:为子路由分配唯一名称,避免与父路由重叠。 2. 重复的路由声明 陷阱:在同一个 Vue 实例中多次声明相同的路由会覆盖以前的声明,导致意外行为。 回避...
    99+
    2024-04-02
  • HTML 标签嵌套的最佳实践:如何避免常见错误
    HTML 标签嵌套是指将一个 HTML 标签放置在另一个 HTML 标签内部。正确的标签嵌套对于网页的结构和样式至关重要。标签嵌套的最佳实践包括: 使用正确的嵌套顺序:HTML 标签的嵌套顺序必须遵循一定的规则,以确保网页的结构清晰。...
    99+
    2024-02-03
    HTML 标签嵌套 最佳实践 错误 搜索引擎优化
  • JavaScript如何监听嵌套页面
    随着Web应用程序的发展,越来越多的网站开始采用嵌套页面的方式来呈现数据,例如嵌套一个iframe来显示另一个网站的内容。在这种情况下,如何在JavaScript中有效地监听嵌套页面的事件呢?首先,我们需要了解一些基本概念。在Web开发中,...
    99+
    2023-05-21
  • JavaScript如何展平嵌套数组
    这篇文章主要为大家展示了“JavaScript如何展平嵌套数组”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JavaScript如何展平嵌套数组”这篇文章吧。展平嵌套数组Array 有一个名为 ...
    99+
    2023-06-27
  • Python 避免字典和元组的多重嵌套问题
    目录一、字典、元组的多重嵌套二、嵌套结构重构为类一、字典、元组的多重嵌套 例 1:记录全班学生的成绩。 分析:定义一个 SimpleGradebook类, 学生名是字典self._g...
    99+
    2024-04-02
  • Python怎么避免字典和元组的多重嵌套
    本文小编为大家详细介绍“Python怎么避免字典和元组的多重嵌套”,内容详细,步骤清晰,细节处理妥当,希望这篇“Python怎么避免字典和元组的多重嵌套”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、字典、元组...
    99+
    2023-07-02
  • JavaScript中怎样避免编写不良代码
    这期内容当中小编将会给大家带来有关JavaScript中怎样避免编写不良代码,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。具有不同接口的替代类由于重复,两个功能相同但接口...
    99+
    2024-04-02
  • PHP 函数中如何避免代码重复?
    使用 php 函数避免代码重复:利用内建函数(例如字符串处理)创建自定义函数封装可重复使用的代码验证用户输入时运用自定义函数验证输入有效性 使用 PHP 函数避免代码重复 在大型代码库...
    99+
    2024-04-27
    php 重复代码
  • java-synchronized 嵌套使用代码详解
    当synchronized使用过多时,可能会造成死锁,那么死锁到底是怎么一回事呢。先看下面的代码,实现死锁://死锁的实现classA{publicvoidget(){System.out.println("A说:我开始启动了,B,给我你的...
    99+
    2023-05-31
    java synchronized java-
  • 在php代码中内嵌javascript代码
    作者:陈业贵 华为云享专家 51cto(专家博主 明日之星 TOP红人) 阿里云专家博主 文章目录 格式:意思:代码:需要注意的地方: 格式: 变量($cyg)=...
    99+
    2023-09-20
    php javascript 前端
  • 如何避免Golang函数内的代码重复?
    为了避免 go 函数中的代码重复,您可以使用以下方法:使用内联函数:将函数体嵌入到函数调用中,减少代码行数。使用匿名函数:定义没有名称的函数,可以立即执行或传递给其他函数,无需命名和调用...
    99+
    2024-04-12
    golang函数 代码重复 git golang
  • ASP IDE并发文件:如何避免代码冲突?
    在团队协作中,多人同时编辑同一个代码文件是常见的情况。然而,这样容易导致代码冲突,进而影响项目进度和代码质量。因此,了解如何避免并发文件问题是很重要的。 一、使用版本控制工具 版本控制工具如Git、SVN等,可以帮助团队成员协作管理代码。...
    99+
    2023-06-18
    ide 并发 文件
  • Git的使用规范:如何避免代码冲突?
    Git是一款广泛使用的版本控制系统,它可以帮助团队协作开发,以及管理代码的版本。但是,当多个人同时修改同一个文件时,就有可能发生代码冲突的情况。本文将介绍Git的使用规范,以及如何避免代码冲突。 1. Git分支管理 Git的分支管理功能可...
    99+
    2023-10-15
    编程算法 javascript git
  • 怎么避免编写pandas代码
    本篇内容主要讲解“怎么避免编写pandas代码”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么避免编写pandas代码”吧!设置from platf...
    99+
    2024-04-02
  • java避免多层嵌套循环用到的一些小技巧分享
    目录避免多层嵌套循环用到的小技巧(1)借用第三个List,使用Contains()方法(2)数据量大,使用HashSet(3)JAVA8及以上使用lambda表达式跳出java中的多...
    99+
    2024-04-02
  • C语言​循环嵌套代码怎么写
    本篇内容主要讲解“C语言循环嵌套代码怎么写”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C语言循环嵌套代码怎么写”吧!循环嵌套代码#include<stdio.h>int ...
    99+
    2023-07-04
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作