成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

JavaScript避免嵌套代碼淺析

瀏覽:26日期:2022-06-01 16:11:45
目錄
  • 前言
  • 一、何為嵌套代碼
  • 二、避免嵌套
    • 1.提煉抽取
    • 2.反轉排列

前言

看過不少過度嵌套的代碼, 我真正意識到問題的嚴重性是剛入職那會, 我在一個老項目里看到了40個連續(xù)的else if, 套了6層的if, forforEach, 因為我們并沒有做什么限制代碼嵌套的提前約定.

呃, 那之后認識到會寫代碼和代碼寫得好完全是兩種概念, 能夠實現復雜的需求也并不能說明代碼寫得好, 開始注重代碼結構方面.

事實是, 很多時候需要編寫的邏輯本身就很惡心, 乍看之下, 堆頁巖般的判定嵌套里似乎每一層都是必要的, 也只能說盡量讓它看起來不那么惡心.

嗯, 比如少來幾次Tab.

一、何為嵌套代碼

嵌套代碼是在函數內部添加更深層級的代碼塊, 放在javascript里, 常用的嵌套手段都包含符號’{‘, 那么對于一個代碼塊, 刨除平級的情況, 其內部的’{'越多就說明這個代碼塊的嵌套深度越大.

也就是: 禁止套娃.

對于以下代碼, 它的嵌套深度為1:

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

而如果在內部加上if語句, 其深度將變?yōu)?:

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

而如果再加一個循環(huán)進去, 深度將變?yōu)?:

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

而…

好的各位, 我最多最多就到這了, 再套下去我就要開始覺得惡心了.在這里可能沒有那么直觀, 而這段代碼放在編輯器里, console.log前面已經有三道豎線了, 光是tab提行就已經開始不舒服了.

在三層嵌套以上, 你所做的一切就不再是一套單一的算法, 這已經開始逐漸演變?yōu)槎鄠€算法的組合了, 是可以做一些封裝抽離而最好不要就這樣混寫在一起.

實戰(zhàn)中三層嵌套絕對連半數以下的計算都處理不了, 那如果還有邏輯沒編寫呢.

二、避免嵌套

1.提煉抽取

提煉(Extraction), 我一般管這叫抽離, 當然, 不一定要抽到外面, 只要能維持嵌套深度處于穩(wěn)定的水平就好(不過函數內實在不能在消減嵌套深度那還是抽到外面形成另外一個函數吧).

比如這段嵌套:

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.

原理十分明了, 就好像在原生環(huán)境獲取DOM, 有的人喜歡這樣:

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

有的人喜歡:

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

抽離提煉就類似于將前者轉化為了后者.

封裝axios也是一樣的道理(不過那更多還是為了避免接口變動導致的被動局面).

2.反轉排列

反轉(Inversion), 對于判定語句, 把正面條件排在負面條件前通常會需要更多的判定, 所以改為優(yōu)先處理負面條件.

先把正面條件放前面:

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, 不過這樣可以節(jié)約一行 )
    return false;
  } 
  for(let i = 0; i < e.length; i++) {
    console.log(e);
  }
}

可以看到現在深度層級由3減小到2.

這種優(yōu)化方法需要先把少數, 需要特殊處理的情況在前面解決完及時退出, 剩下的多數情況就可以不放在判定語句中.

而在這個過程中, 需要把最特殊, 且不將其他特殊情況包含在內的情況寫在前面, 越特殊, 越提前處理, 此處e.length === 2為最特殊, 而e.length < 5這個特殊情況將e.length === 2包含在內, 所以應當第二個處理.

我在前面也寫過這種做法, 將判定嵌套改為平次的衛(wèi)語句, 稱作validation gatekepping, 感興趣的話可以去看這篇:

不過還可以在平次判定這個基礎上使用這個技巧, 我們把負面情況放在靠前的平次判定處理, 如果處理中途出現過多嵌套, 那就提煉抽離, 把正面條件放最后:

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又不能終止執(zhí)行, 那么這兩個特殊條件在一輪循環(huán)中都會被執(zhí)行.

本著要把正面條件處理方案寫最后的原則, 直接在最后一個特殊條件不滿足(按照上文所述寫法, 最后一個特殊條件不滿足說明前面所列特殊條件均不滿足)時執(zhí)行正面條件處理方案.

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];
}

只是判定需求不同罷了.

上面這種寫法是在所有負面條件不滿足時執(zhí)行正面條件處理方案.

前面反轉的例子是在任意負面條件不滿足時結束執(zhí)行.

但遵循兩種優(yōu)化手段的原則都可以實施優(yōu)化.

到此這篇關于JavaScript避免嵌套代碼淺析的文章就介紹到這了,更多相關JS避免嵌套代碼內容請搜索以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持!

標簽: JavaScript
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
91一区一区三区| 久久国产日韩欧美精品| 另类小说视频一区二区| 免费在线亚洲| 一区二区三区不卡在线观看| 午夜精品电影| 久久亚洲免费视频| 国产大片一区二区| 欧美一级国产精品| 国产精品夜夜嗨| 91精品国产综合久久精品性色| 国产自产v一区二区三区c| 欧美日韩你懂的| 国产一区91精品张津瑜| 91精品国产综合久久福利软件| 国内精品写真在线观看| 欧美精品久久久久久久多人混战 | 国产精品日日摸夜夜摸av| 欧美91大片| 国产精品三级视频| 一区精品在线| 亚洲激情av在线| 亚洲欧美日韩国产| 午夜视频一区二区| 欧美性大战久久久久久久蜜臀| 日韩精品每日更新| 欧美三级乱人伦电影| 国产一区二区看久久| 91精品国产综合久久精品麻豆| 国产精品资源在线| 欧美成人福利视频| 欧美+亚洲+精品+三区| 成人一区二区三区视频在线观看| 精品久久人人做人人爱| 91丝袜国产在线播放| 欧美国产激情一区二区三区蜜月| 海角社区69精品视频| 一区二区三区在线不卡| 久久蜜桃资源一区二区老牛| 久久国产精品色婷婷| 日韩午夜av一区| 欧美日韩亚洲免费| 亚洲一区二区三区四区五区黄 | 免费日韩av| 男男gaygay亚洲| 欧美男人的天堂一二区| 成人三级在线视频| 国产精品女人毛片| 亚洲女同在线| 极品瑜伽女神91| 欧美精品一区二区三区高清aⅴ| 欧美福利在线| 亚洲午夜精品一区二区三区他趣| 一本色道久久综合亚洲aⅴ蜜桃 | 精品国产免费人成在线观看| 欧美黄色一区| 亚洲一区视频在线| 欧美老人xxxx18| 91原创在线视频| 亚洲另类色综合网站| 日本精品视频一区二区| 国产91在线观看| **欧美大码日韩| 欧美三级三级三级爽爽爽| 99精品在线免费| 亚洲精品国产品国语在线app| 91福利在线观看| www.亚洲激情.com| 亚洲欧美另类久久久精品| 欧美午夜精品久久久久久孕妇| 不卡欧美aaaaa| 亚洲精品免费在线播放| 欧美日韩亚洲综合一区二区三区| 91蜜桃传媒精品久久久一区二区| 一区二区三区欧美亚洲| 欧美日韩一级片在线观看| 91在线精品秘密一区二区| 一二三四区精品视频| 7777精品伊人久久久大香线蕉完整版 | 精品精品国产高清a毛片牛牛| 激情一区二区三区| 强制捆绑调教一区二区| 国产女主播视频一区二区| 久久久精品午夜少妇| 成人性生交大合| 亚洲一级片在线观看| 日韩欧美国产精品一区| 国产精品手机视频| 成人激情电影免费在线观看| 亚洲男同性视频| 91精品国产色综合久久不卡电影 | 亚洲精品视频免费看| 91精品国产全国免费观看| 亚洲二区精品| 国产一区二区三区不卡在线观看 | 韩国理伦片一区二区三区在线播放| 国产亚洲va综合人人澡精品| 久久久国产亚洲精品| 91麻豆成人久久精品二区三区| 天天av天天翘天天综合网色鬼国产| 精品sm在线观看| 色乱码一区二区三区88| 国产一区免费视频| 国产一区高清在线| 一区二区成人在线| 久久综合狠狠综合久久综合88| 一本久久a久久免费精品不卡| 欧美freesex交免费视频| 美国精品在线观看| 亚洲人成网站色在线观看| 欧美大片顶级少妇| 久久亚洲图片| 亚洲国产激情| a美女胸又www黄视频久久| 免费高清在线一区| 亚洲精选视频在线| 久久久久高清精品| 欧美二区乱c少妇| 久久久久天天天天| 亚洲国产精品视频一区| 99免费精品视频| 久久99国产精品久久99果冻传媒| 亚洲精品免费在线| 久久久精品国产99久久精品芒果 | 欧美喷水视频| 国产凹凸在线观看一区二区| 日日夜夜一区二区| 亚洲老妇xxxxxx| 国产视频一区二区三区在线观看| 91精品国产色综合久久ai换脸 | av网站免费线看精品| 蜜桃av一区二区三区电影| 亚洲免费观看高清完整版在线| 久久这里只有精品6| 91精品国产综合久久久蜜臀图片| 色婷婷av久久久久久久| 亚洲精品在线观看免费| 欧美激情五月| av在线不卡网| 国产成人激情av| 精品sm捆绑视频| 欧美一区二区三区四区视频| 欧美亚洲精品一区| 久久精品中文| 香蕉国产精品偷在线观看不卡| 国产成人在线观看| 激情六月婷婷久久| 日本午夜一区二区| 亚洲第一会所有码转帖| 亚洲免费观看视频| 亚洲色欲色欲www| 国产精品毛片久久久久久久| 久久精品欧美一区二区三区不卡| 日韩色在线观看| 欧美丰满一区二区免费视频| 欧美日韩一区二区三区在线看| 色婷婷精品久久二区二区蜜臀av | av男人天堂一区| 国内精品久久久久影院色| 蜜桃视频一区二区三区在线观看| 亚洲风情在线资源站| 一区二区国产盗摄色噜噜| 亚洲免费大片在线观看| 亚洲女人****多毛耸耸8| 亚洲欧洲另类国产综合| 中文字幕不卡在线播放| 中文字幕精品综合| 中文字幕av一区二区三区| 国产精品婷婷午夜在线观看| 国产色婷婷亚洲99精品小说| 久久午夜国产精品| 久久中文娱乐网| 久久久国产精华| 国产欧美视频一区二区三区| 国产欧美日韩视频在线观看| 国产日韩一级二级三级| 中国av一区二区三区| 亚洲色图在线看| 亚洲一区在线视频观看| 香蕉久久夜色精品国产使用方法| 亚洲电影一级片| 丝袜a∨在线一区二区三区不卡| 五月婷婷久久丁香| 日韩av网站在线观看| 久久精品国产77777蜜臀| 久久99最新地址| 国产原创一区二区三区| 国产91精品一区二区麻豆亚洲| 成人小视频免费在线观看| 不卡一二三区首页| 欧美精品97| 国产区欧美区日韩区| 亚洲综合精品| 欧美综合一区二区三区| 欧美美女bb生活片| 日韩精品一区二区三区老鸭窝| 久久免费视频一区| 国产精品传媒入口麻豆| 一区二区欧美精品| 美女久久久精品|