gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区

站長資訊網(wǎng)
最全最豐富的資訊網(wǎng)站

一文教你實(shí)現(xiàn)JavaScript if分支優(yōu)化

1000個(gè)判斷條件難道要寫了1000個(gè) if ?要怎么優(yōu)化if分支語句?下面本篇文章就來帶大家聊聊怎么實(shí)現(xiàn)分支優(yōu)化,希望對(duì)大家有所幫助!

一文教你實(shí)現(xiàn)JavaScript if分支優(yōu)化

最近在網(wǎng)上沖浪時(shí)看到了這樣一段代碼:

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("此人比較神秘!");     } }
登錄后復(fù)制

咋一看沒感覺有什么異常,但如果有1000個(gè)判斷條件,按照這種寫法難不成要寫1000個(gè) if 分支?

如果寫了大量的 if 分支,并且可能還具有分支套分支,可以想象到整個(gè)代碼的可讀性和可維護(hù)都會(huì)大大降低,這在實(shí)際開發(fā)中,確實(shí)是一個(gè)比較頭疼的問題,那有沒有什么辦法能夠即實(shí)現(xiàn)需求又能避免這些問題呢?【推薦學(xué)習(xí):javascript視頻教程】

1️⃣ 簡單分支優(yōu)化

這就涉及到分支優(yōu)化,讓我們轉(zhuǎn)換思維,去優(yōu)化一下上面的代碼結(jié)構(gòu):

function getUserDescribe(name) {     const describeForNameMap = {         小劉: () => console.log("劉哥哥"),         小紅: () => console.log("小紅妹妹"),         陳龍: () => console.log("大師"),         李龍: () => console.log("師傅"),         大鵬: () => console.log("惡人"),     };     describeForNameMap[name] ? describeForNameMap[name]() : console.log("此人比較神秘!"); }
登錄后復(fù)制

問題代碼中的判斷都是簡單的相等判斷,那么我們就可以將這些判斷條件作為一個(gè)屬性寫到對(duì)象describeForNameMap 中去,這些屬性對(duì)應(yīng)的值就是條件成立后的處理函數(shù)。

之后我們就只需通過getUserDescribe函數(shù)接收到的參數(shù)去獲取describeForNameMap對(duì)象中對(duì)應(yīng)的值,如果該值存在就運(yùn)行該值(因?yàn)橹凳且粋€(gè)函數(shù))。

這樣一來原本的 if 分支判斷就轉(zhuǎn)換成了簡單的key value對(duì)應(yīng)值,條件與處理函數(shù)一一對(duì)應(yīng),一目了然。

2️⃣ 復(fù)雜分支優(yōu)化

那如果我們的 if 分支中的判斷條件不只是簡單的相等判斷,還具有一些需要計(jì)算的表達(dá)式時(shí),我們?cè)撛趺崔k呢?(如下所示)

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("此人比較神秘!");     } }
登錄后復(fù)制

對(duì)于這種結(jié)構(gòu)的代碼就不能引入對(duì)象來進(jìn)行分支優(yōu)化了,我們可以引入二維數(shù)組來進(jìn)行分支優(yōu)化:

function getUserDescribe(name) {     const describeForNameMap = [         [             (name) => name.length > 3, // 判斷條件             () => console.log("名字太長") // 執(zhí)行函數(shù)         ],         [             (name) => name.length < 2,              () => console.log("名字太短")         ],         [             (name) => name[0] === "陳",              () => console.log("小陳")         ],         [             (name) => name === "大鵬",              () => console.log("管理員")         ],         [             (name) => name[0] === "李" && name !== "李鵬",             () => console.log("小李"),         ],     ];     // 獲取符合條件的子數(shù)組     const getDescribe = describeForNameMap.find((item) => item[0](name));     // 子數(shù)組存在則運(yùn)行子數(shù)組中的第二個(gè)元素(執(zhí)行函數(shù))     getDescribe ? getDescribe[1]() : console.log("此人比較神秘!"); }
登錄后復(fù)制

上面我們定義了一個(gè)describeForNameMap數(shù)組,數(shù)組內(nèi)的每一個(gè)元素代表一個(gè)判斷條件與其執(zhí)行函數(shù)的集合(也是一個(gè)數(shù)組),之后我們通過數(shù)組的find方法查找describeForNameMap數(shù)組中符合判斷條件的子數(shù)組即可。

3️⃣ 抽離分支

上面例子中我們定義的這個(gè)describeForNameMap對(duì)象是一個(gè)獨(dú)立的結(jié)構(gòu),我們完全可以將它抽離出去:

const describeForNameMap = {     小劉: () => console.log("劉哥哥"),     小紅: () => console.log("小紅妹妹"),     陳龍: () => console.log("大師"),     李龍: () => console.log("師傅"),     大鵬: () => console.log("惡人"), };  function getUserDescribe(name) {     describeForNameMap[name] ? describeForNameMap[name]() : console.log("此人比較神秘!"); }
登錄后復(fù)制

const describeForNameMap = [     [         (name) => name.length > 3, // 判斷條件         () => console.log("名字太長") // 執(zhí)行函數(shù)     ],     [         (name) => name.length < 2,          () => console.log("名字太短")     ],     [         (name) => name[0] === "陳",          () => console.log("小陳")     ],     [         (name) => name === "大鵬",          () => console.log("管理員")     ],     [         (name) => name[0] === "李" && name !== "李鵬",         () => console.log("小李"),     ], ];      function getUserDescribe(name) {     // 獲取符合條件的子數(shù)組     const getDescribe = describeForNameMap.find((item) => item[0](name));     // 子數(shù)組存在則運(yùn)行子數(shù)組中的第二個(gè)元素(執(zhí)行函數(shù))     getDescribe ? getDescribe[1]() : console.log("此人比較神秘!"); }
登錄后復(fù)制

通過模塊化的開發(fā)也可以將這個(gè)map對(duì)象寫進(jìn)一個(gè)單獨(dú)的js文件,之后在需要使用的地方導(dǎo)入即可。

4️⃣ 爭議

這樣一來整個(gè)getUserDescribe函數(shù)就變得非常簡潔,有的同學(xué)可能會(huì)問這有什么用呢?這不是更加麻煩了嗎?如果真的嫌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("此人比較神秘!"); }
登錄后復(fù)制

試想一下,如果你getUserDescribe函數(shù)中有1000個(gè)判斷分支,并且還具有大量的根據(jù)判斷結(jié)果來執(zhí)行的處理代碼,并且getUserDescribe函數(shù)會(huì)返回這個(gè)處理后的判斷結(jié)果的值。

這時(shí)getUserDescribe函數(shù)的重點(diǎn)在于對(duì)判斷結(jié)果的處理,而不在于這個(gè)結(jié)果是通過什么分支獲取的,例如:

function getUserDescribe(name) {     let str; // 存儲(chǔ)判斷結(jié)果     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 = "此人比較神秘!";     }     // 對(duì)判斷結(jié)果str的一些處理     // ......     console.log(str);     return str; }
登錄后復(fù)制

如果你不進(jìn)行分支優(yōu)化,getUserDescribe函數(shù)就會(huì)被大量的 if 分支搶占空間,使得getUserDescribe函數(shù)的重點(diǎn)迷失(getUserDescribe函數(shù)重點(diǎn)在于對(duì)判斷結(jié)果的處理,而不在于這個(gè)結(jié)果是通過什么分支獲取的),這時(shí)你再看一下我們優(yōu)化后的代碼:

const describeForNameMap = [     [(name) => name.length > 3, () => "名字太長"],     [(name) => name.length < 2, () => "名字太短"],     [(name) => name[0] === "陳", () => "小陳"],     [(name) => name === "大鵬", () => "管理員"],     [(name) => name[0] === "李" && name !== "李鵬", () => "小李"], ];  function getUserDescribe(name) {     let str; // 存儲(chǔ)判斷結(jié)果     const getDescribe = describeForNameMap.find((item) => item[0](name));     if (getDescribe) {         str = getDescribe[1]();     } else {         str = "此人比較神秘!";     }     // 對(duì)判斷結(jié)果str的一些處理     // ......     console.log(str);     return str; }
登錄后復(fù)制

查看優(yōu)化后的getUserDescribe函數(shù)我們能夠知道,它從describeForNameMap獲取了一個(gè)值賦值給了strdescribeForNameMap是如何返回值的我們并不關(guān)心),之后對(duì)str作了一些處理。這就突出了getUserDescribe函數(shù)的重點(diǎn)(對(duì)判斷結(jié)果str進(jìn)行處理)。

在這個(gè)例子中describeForNameMap子數(shù)組的第二個(gè)元素完全可以直接使用一個(gè)值:[(name) => name.length > 3, "名字太長"],但為了整體代碼的可擴(kuò)展性,推薦還是使用函數(shù),因?yàn)楹瘮?shù)可以接收參數(shù),方便應(yīng)對(duì)之后更復(fù)雜的場景。

? 結(jié)語

分支優(yōu)化在各種語言中都有不同的實(shí)現(xiàn)方式和應(yīng)用場景,本篇通過JavaScript介紹了兩種代碼分支優(yōu)化的思想,代碼的實(shí)現(xiàn)非常簡單,重點(diǎn)在于這種思想的應(yīng)用。

其實(shí)關(guān)于分支優(yōu)化這個(gè)問題一直存在爭議,目前存在兩種觀點(diǎn):

  • 觀點(diǎn)1:壓根不需要多此一舉去優(yōu)化它,并且優(yōu)化后的代碼因?yàn)槎鄤?chuàng)建了一個(gè)對(duì)象/數(shù)組,對(duì)對(duì)象/數(shù)組進(jìn)行檢索反而比單純的if else還是廢性能。
  • 觀點(diǎn)2:分支優(yōu)化后的代碼可讀性/可維護(hù)性更好,并且引入對(duì)象/數(shù)組所帶來的性能問題在當(dāng)今時(shí)代根本不值一提。

你是什么觀點(diǎn)呢?

贊(0)
分享到: 更多 (0)
網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)
gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区
国产成人免费高清视频| 无码中文字幕色专区| 成年人视频观看| av 日韩 人妻 黑人 综合 无码| 天天干在线影院| 精品国产一区三区| 国产精品专区在线| 加勒比海盗1在线观看免费国语版| 在线观看中文av| 在线观看日本www| 亚洲自拍第三页| 日韩欧美视频免费在线观看| 4444亚洲人成无码网在线观看| 特大黑人娇小亚洲女mp4| 免费看日本黄色| 三上悠亚久久精品| 妞干网在线免费视频| 人人干人人干人人| 欧美性受xxxx黒人xyx性爽| 国产又大又长又粗又黄| 轻点好疼好大好爽视频| 无罩大乳的熟妇正在播放| 亚洲乱码中文字幕久久孕妇黑人| 午夜肉伦伦影院| 中文字幕 日韩 欧美| av中文字幕av| 男人的天堂99| 91成人在线视频观看| 9久久9毛片又大又硬又粗| 免费在线观看的av网站| 亚洲欧美日韩三级| 精品免费久久久久久久| 日韩一级在线免费观看| www.久久com| 日本午夜激情视频| 色婷婷成人在线| 日本人体一区二区| 国产精品自拍视频在线| 国产手机免费视频| av在线网址导航| 内射国产内射夫妻免费频道| 亚洲免费av一区| 成人免费观看视频在线观看| 玖玖精品在线视频| 最新中文字幕免费视频| 18禁裸男晨勃露j毛免费观看| 99久久国产综合精品五月天喷水| 亚洲 欧美 另类人妖| 农民人伦一区二区三区| 日韩成人av免费| 四季av一区二区| jizzjizz国产精品喷水| 日本免费成人网| 国内av免费观看| 污视频网址在线观看| aⅴ在线免费观看| 日韩视频一二三| 日韩av福利在线观看| 91极品尤物在线播放国产| 成人免费毛片网| 国产二级片在线观看| 日韩成人三级视频| 日韩中文字幕亚洲精品欧美| 午夜激情视频网| 久久久国产精华液999999| 欧美日韩在线免费播放| 天天摸天天碰天天添| 亚洲国产精品无码观看久久| 国产精品无码免费专区午夜| 国产精品无码乱伦| www.-级毛片线天内射视视| www激情五月| 三级在线免费观看| 美女av免费观看| 97视频在线免费| 国产白丝袜美女久久久久| www.亚洲视频.com| 亚洲美免无码中文字幕在线| 日韩精品 欧美| 999香蕉视频| 亚洲综合日韩欧美| 久久免费看毛片| 又大又硬又爽免费视频| 日韩在线xxx| 日本中文字幕精品—区二区| 亚洲一二三av| 成人在线国产视频| 丰满少妇在线观看| 九九久久久久久| 精品少妇人妻av免费久久洗澡| 噜噜噜久久亚洲精品国产品麻豆| 亚洲中文字幕无码不卡电影| 日韩一级免费在线观看| 黄色a级三级三级三级| 国产成人永久免费视频| 成年人在线观看视频免费| 8x8x成人免费视频| 欧美午夜小视频| 中文字幕永久视频| 国产在线无码精品| 91视频免费版污| 日本黄网站色大片免费观看| 国产主播在线看| 97久久国产亚洲精品超碰热| 国产精品免费观看久久| 香蕉视频xxxx| 日本888xxxx| 国产精品333| 一级黄色高清视频| 中文字幕国内自拍| 18禁免费无码无遮挡不卡网站| 桥本有菜av在线| 欧美男女交配视频| aaa毛片在线观看| 免费看日本黄色| 看全色黄大色大片| 一区二区三区四区毛片| 熟女性饥渴一区二区三区| 天天在线免费视频| 日本成人xxx| 日本高清久久久| 男女视频在线看| 国产精品69页| 97成人在线观看视频| 少妇无码av无码专区在线观看 | 国产真人无码作爱视频免费| 国产美女主播在线| 老司机午夜网站| 国产一二三四五| 免费看污污视频| 狠狠干视频网站| 成人免费a级片| wwwwww欧美| 亚洲精品蜜桃久久久久久| 国产成人一二三区| 久久av高潮av| 天堂…中文在线最新版在线| 波多野结衣之无限发射| 久操网在线观看| 日本在线观看a| 国产嫩草在线观看| 亚洲欧美日本一区二区三区| 91小视频在线播放| 一级性生活视频| 日韩欧美在线播放视频| 看欧美ab黄色大片视频免费| 国产日韩成人内射视频| 在线观看国产一级片| 97人人模人人爽人人澡| 成人免费观看在线| 日本在线视频www| 天堂视频免费看| 一二三在线视频| 免费 成 人 黄 色| 五月婷婷之综合激情| 日本一本在线视频| 久久成人福利视频| 麻豆三级在线观看| 五月天激情图片| 久久无码高潮喷水| 天天做天天干天天操| 亚洲中文字幕无码一区二区三区| 九一国产精品视频| 日本高清免费在线视频| 亚洲不卡中文字幕无码| 五月天视频在线观看| 狠狠97人人婷婷五月| 爱情岛论坛亚洲首页入口章节| 特级毛片在线免费观看| 日韩欧美在线播放视频| 视频一区二区视频| 六月丁香婷婷在线| www国产无套内射com| 免费国产成人av| 黄页网站大全在线观看| www.午夜色| 亚洲欧美激情网| 日韩国产欧美亚洲| 亚洲国产精品影视| 国产免费又粗又猛又爽| 免费不卡av在线| 国产成人免费高清视频| 免费看涩涩视频| 久热免费在线观看| 高清在线观看免费| 又大又硬又爽免费视频| 国产乱叫456| 亚洲免费成人在线视频| 欧美污视频网站| 国产在线观看福利| 成年人观看网站| 无码人妻丰满熟妇区96| 18黄暴禁片在线观看| 欧美少妇一级片| 免费观看国产视频在线| 伊人五月天婷婷| 久久久精品视频国产| 亚洲欧美日韩不卡| 国产女人18毛片| 色婷婷777777仙踪林|