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

站長資訊網
最全最豐富的資訊網站

一文教你實現JavaScript if分支優化

1000個判斷條件難道要寫了1000個 if ?要怎么優化if分支語句?下面本篇文章就來帶大家聊聊怎么實現分支優化,希望對大家有所幫助!

一文教你實現JavaScript if分支優化

最近在網上沖浪時看到了這樣一段代碼:

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

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

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

1️⃣ 簡單分支優化

這就涉及到分支優化,讓我們轉換思維,去優化一下上面的代碼結構:

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

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

之后我們就只需通過getUserDescribe函數接收到的參數去獲取describeForNameMap對象中對應的值,如果該值存在就運行該值(因為值是一個函數)。

這樣一來原本的 if 分支判斷就轉換成了簡單的key value對應值,條件與處理函數一一對應,一目了然。

2️⃣ 復雜分支優化

那如果我們的 if 分支中的判斷條件不只是簡單的相等判斷,還具有一些需要計算的表達式時,我們該怎么辦呢?(如下所示)

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

對于這種結構的代碼就不能引入對象來進行分支優化了,我們可以引入二維數組來進行分支優化:

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

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

3️⃣ 抽離分支

上面例子中我們定義的這個describeForNameMap對象是一個獨立的結構,我們完全可以將它抽離出去:

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

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

通過模塊化的開發也可以將這個map對象寫進一個單獨的js文件,之后在需要使用的地方導入即可。

4️⃣ 爭議

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

試想一下,如果你getUserDescribe函數中有1000個判斷分支,并且還具有大量的根據判斷結果來執行的處理代碼,并且getUserDescribe函數會返回這個處理后的判斷結果的值。

這時getUserDescribe函數的重點在于對判斷結果的處理,而不在于這個結果是通過什么分支獲取的,例如:

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

如果你不進行分支優化,getUserDescribe函數就會被大量的 if 分支搶占空間,使得getUserDescribe函數的重點迷失(getUserDescribe函數重點在于對判斷結果的處理,而不在于這個結果是通過什么分支獲取的),這時你再看一下我們優化后的代碼:

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

查看優化后的getUserDescribe函數我們能夠知道,它從describeForNameMap獲取了一個值賦值給了strdescribeForNameMap是如何返回值的我們并不關心),之后對str作了一些處理。這就突出了getUserDescribe函數的重點(對判斷結果str進行處理)。

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

? 結語

分支優化在各種語言中都有不同的實現方式和應用場景,本篇通過JavaScript介紹了兩種代碼分支優化的思想,代碼的實現非常簡單,重點在于這種思想的應用。

其實關于分支優化這個問題一直存在爭議,目前存在兩種觀點:

  • 觀點1:壓根不需要多此一舉去優化它,并且優化后的代碼因為多創建了一個對象/數組,對對象/數組進行檢索反而比單純的if else還是廢性能。
  • 觀點2:分支優化后的代碼可讀性/可維護性更好,并且引入對象/數組所帶來的性能問題在當今時代根本不值一提。

你是什么觀點呢?

贊(0)
分享到: 更多 (0)
?
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区
两根大肉大捧一进一出好爽视频| 日韩欧美不卡在线| 青青草成人免费在线视频| 五月天av影院| av电影一区二区三区| 九九热精品国产| 亚洲自拍第三页| 北条麻妃亚洲一区| 亚洲天堂av一区二区| 亚洲妇熟xx妇色黄蜜桃| 奇米777在线视频| 国产欧美123| 97超碰在线视| 免费无码av片在线观看| 亚洲精品一二三四五区| the porn av| 亚洲男人天堂2021| 99er在线视频| 无遮挡又爽又刺激的视频| 九九热免费精品视频| 99热一区二区| 你真棒插曲来救救我在线观看| 成年人午夜免费视频| 最新中文字幕免费视频| 亚洲一级片免费观看| 欧美亚洲黄色片| 日本三级黄色网址| 干日本少妇视频| 精品99在线视频| 午夜啪啪小视频| 黄色国产一级视频| 手机在线成人免费视频| 国产黄色激情视频| 天天操天天爽天天射| 91视频 - 88av| 性生交免费视频| 屁屁影院ccyy国产第一页| 日韩a在线播放| 50度灰在线观看| 色91精品久久久久久久久| 久久久久久www| 特级黄色片视频| 国产精品无码av无码| 福利视频免费在线观看| 三级av免费观看| 男人的天堂99| 欧美日韩激情四射| 国产资源中文字幕| 中文字幕永久视频| 欧美爱爱视频免费看| 久久艹这里只有精品| 国产视频在线视频| 少妇av一区二区三区无码| 99久re热视频精品98| 五月天婷婷在线观看视频| 大肉大捧一进一出好爽动态图| 三级在线免费观看| 成人手机在线播放| 自拍偷拍视频在线| 国产又粗又长又大的视频| 水蜜桃色314在线观看| 久久这里只有精品8| 免费看av软件| 国产精品久久a| www亚洲成人| 日本三级黄色网址| 天堂视频免费看| 久久精品免费一区二区| 欧美一区二区激情| 青青视频免费在线| www.成年人视频| 日韩中字在线观看| 人人干视频在线| 无遮挡又爽又刺激的视频| 黄色国产精品视频| 国产免费视频传媒| 欧美视频国产视频| 久久久一二三四| 国产黄色片免费在线观看| 日本福利视频一区| 无码人妻精品一区二区三区在线| 性一交一乱一伧国产女士spa| 91九色丨porny丨国产jk| 人妻熟妇乱又伦精品视频| 亚欧在线免费观看| 校园春色 亚洲色图| 午夜av中文字幕| www插插插无码免费视频网站| 欧美午夜小视频| 五月天婷婷激情视频| 亚洲欧美偷拍另类| 黄色一级片黄色| 欧美日韩一区二区在线免费观看| 手机在线成人免费视频| 国产又黄又爽免费视频| 青青青国产在线观看| 日韩精品你懂的| 免费高清一区二区三区| 成人在线激情网| 人妻无码一区二区三区四区| 国产二级片在线观看| 日韩va在线观看| 日本免费黄视频| 强伦女教师2:伦理在线观看| 国产 日韩 亚洲 欧美| 五月天av在线播放| 91丨porny丨探花| 亚洲三级在线观看视频| 欧美午夜小视频| 久久精品一二三四| 18禁网站免费无遮挡无码中文| 日韩欧美亚洲另类| 国产青青在线视频| 1314成人网| 亚洲 欧美 日韩系列| 欧美日韩精品在线一区二区 | 美女扒开大腿让男人桶| 尤蜜粉嫩av国产一区二区三区| 久久男人资源站| 波多野结衣国产精品| 青青在线免费观看视频| 精品国产一区二区三区无码| 九九热精品国产| 91小视频网站| 国产又大又硬又粗| 日韩欧美精品免费| www.亚洲成人网| 欧美黄网在线观看| 黄色a级三级三级三级| 狠狠干狠狠操视频| 国产成人精品无码播放| 欧美三级午夜理伦三级| 播放灌醉水嫩大学生国内精品| 日本a级片在线播放| 久久精品国产精品亚洲精品色| 一级黄色特级片| 天天看片天天操| 天天看片天天操| 黄色影视在线观看| 欧美黄色免费网址| 男女视频网站在线观看| 鲁一鲁一鲁一鲁一色| 无码aⅴ精品一区二区三区浪潮 | 黄网站欧美内射| 五月丁香综合缴情六月小说| 国产freexxxx性播放麻豆| 日韩伦理在线免费观看| 国产青草视频在线观看| 国内精品在线观看视频| 成人黄色片视频| 国产色视频在线播放| √天堂资源在线| 久久视频免费在线| 久久久999免费视频| 国产精品igao| 国产女主播av| 国产激情在线观看视频| 少妇一级淫免费放| 黄色一级片国产| 99草草国产熟女视频在线| 久久艹这里只有精品| 国产精品12345| 五月天激情播播| cao在线观看| 奇米影音第四色| 亚洲理论电影在线观看| 免费观看成人网| 97超碰人人看| 日本熟妇人妻xxxxx| 亚洲av毛片在线观看| 国产日产欧美视频| 亚洲一区二区图片| 成人免费无码av| 亚洲精品蜜桃久久久久久| 第四色婷婷基地| 欧美爱爱视频免费看| 天天干天天色天天爽| 国产l精品国产亚洲区久久| 999久久久精品视频| 日本wwww视频| 无码粉嫩虎白一线天在线观看| 在线观看岛国av| 日韩福利视频在线| 天堂8在线天堂资源bt| 一级黄色片国产| 久久久久国产一区| aa在线免费观看| 欧美极品欧美精品欧美| 老司机午夜网站| 亚洲综合激情视频| 色多多视频在线播放| 青青青国产在线视频| a√天堂在线观看| 女人喷潮完整视频| 日本黄色片一级片| 国产高清精品软男同| 亚洲色图欧美自拍| www.污网站| 亚洲av首页在线| 婷婷视频在线播放|