亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript中判斷的優(yōu)雅寫法示例

 更新時(shí)間:2021年10月17日 11:29:28   作者:冰冰你個(gè)小可愛(ài)  
判斷語(yǔ)句這個(gè)我們不陌生,就是判斷是否滿足指定的條件,如果滿足則執(zhí)行一定的代碼,否則跳過(guò),下面這篇文章主要給大家介紹了關(guān)于JavaScript中判斷的優(yōu)雅寫法,需要的朋友可以參考下

前言

我們?cè)趯?JavaScript 時(shí)經(jīng)常遇到一些邏輯判斷,可以使用 if/else 或者 switch 來(lái)實(shí)現(xiàn),但是對(duì)于復(fù)雜的判斷,過(guò)多的條件往往會(huì)讓我們的代碼變得冗長(zhǎng),可讀性下降。故我們需要優(yōu)化我們的代碼,使之更優(yōu)雅💎。

一、一元判斷

1.1 舉個(gè)例子🌰

我們寫一個(gè)常見(jiàn)的 if/else 判斷的函數(shù),然后對(duì)他進(jìn)行優(yōu)化。

const myFunction = (status) => {
  if (status === 1) {
    console.log("status1");
  } else if (status === 2) {
    console.log("status2");
  } else if (status === 3) {
    console.log("status3");
  }
};

1.2 放入 Object 中

我們知道, JavaScript 的 Object 其實(shí)就是一些 鍵值對(duì) 的無(wú)序集合,正因如此我們可以借助其存放判斷的條件。例如上述情況,判斷條件是一個(gè)數(shù)字類型,后續(xù)操作也僅僅是用到了一個(gè)字符串,這時(shí)我們就可以創(chuàng)建一個(gè)對(duì)象,把所用到的數(shù)字和字符串分別作為 Object 的鍵名和對(duì)應(yīng)值。

// 將判斷條件放入 Object 中
const statusObj = {
  1: "status1",
  2: "status2",
  3: "status3",
};

// 優(yōu)化后函數(shù)💎
const myFunction = (status) => {
  console.log(statusObj[status]);
};

1.3 放入 Map 中

除了原始對(duì)象以外,我們還可以使用 Map 對(duì)象。我們來(lái)看下 MDN 對(duì)其的描述:

Map 對(duì)象保存鍵值對(duì),并且能夠記住鍵的原始插入順序。任何值(對(duì)象或者原始值) 都可以作為一個(gè)鍵或一個(gè)值。

不難看出,Map 對(duì)象其實(shí)就是普通對(duì)象的加強(qiáng)版,特別是任何值都可以作為其鍵值對(duì),這意味著 函數(shù) 、 正則 等也可以作為其鍵或值,這也就大大方便了我們將其作為判斷的操作。具體關(guān)于 Map 對(duì)象的細(xì)節(jié)此處不再展開(kāi)。

// 將判斷條件放入 Map 中
const statusMap = new Map([
  [1, "status1"],
  [2, "status2"],
  [3, "status3"],
]);

// 優(yōu)化后函數(shù)💎
const myFunction = (status) => {
  console.log(statusMap.get(status));
};

二、多元判斷

2.1 舉個(gè)例子🌰

既然一元判斷可以優(yōu)化,那么多元判斷也可以進(jìn)行優(yōu)化,下面是有兩種判斷條件的案例。

// 舉個(gè)例子🌰
const myFunction = (right, status) => {
  if (right === "administrator" && status === 1) {
    console.log("管理員喜歡王冰冰");
  } else if (right === "administrator" && status === 2) {
    console.log("管理員不喜歡王冰冰");
  } else if (right === "user" && status === 1) {
    console.log("用戶喜歡王冰冰");
  } else if (right === "user" && status === 2) {
    console.log("用戶不喜歡王冰冰");
  }
};

// 有重復(fù)情況的例子🌰
const myFunction = (right, status) => {
  if (right === "administrator" && status === 1) {
    console.log("管理員喜歡王冰冰");
  } else if (right === "administrator" && status === 2) {
    console.log("管理員喜歡王冰冰");
  } else if (right === "user" && status === 1) {
    console.log("用戶喜歡王冰冰");
  } else if (right === "user" && status === 2) {
    console.log("用戶喜歡王冰冰");
  }
};

2.2 將判斷條件拼成字符串放入 Object 中

兩種情況也同樣可以用 Object 進(jìn)行優(yōu)化。

// 優(yōu)化"例子🌰"

// 將判斷條件放入 Object 中
const actionsObj = {
  "administrator-1": "管理員喜歡王冰冰",
  "administrator-2": "管理員不喜歡王冰冰",
  "user-1": "用戶喜歡王冰冰",
  "user-2": "用戶不喜歡王冰冰",
};

// 優(yōu)化后函數(shù)💎
const myFunction = (right, status) => {
  console.log(actionsObj[`${right}-${status}`]);
};

// 可以將函數(shù)作為"value",以下幾種情況類似,不再贅述🥕
const actionsObj = {
  "administrator-1": () => console.log("管理員喜歡王冰冰"),
  "administrator-2": () => console.log("管理員喜歡王冰冰"),
  "user-1": () => console.log("管理員喜歡王冰冰"),
  "user-2": () => console.log("管理員喜歡王冰冰"),
};

// 優(yōu)化后函數(shù)💎
const myFunction = (right, status) => {
  actionsObj[`${right}-${status}`]();
};

// 優(yōu)化"有重復(fù)情況的例子🌰"
// 可以提取公共函數(shù),以下幾種情況類似,不再贅述🍓
const actions = () => {
  const f1 = () => console.log("管理員喜歡王冰冰");
  const f2 = () => console.log("用戶喜歡王冰冰");

  return {
    "administrator-1": f1,
    "administrator-2": f1,
    "user-1": f2,
    "user-2": f2,
  };
};

// 優(yōu)化后函數(shù)💎
const myFunction = (right, status) => {
  actions()[`${right}-${status}`]();
};

2.3 將判斷條件拼成字符串放入 Map 中

同樣的,我們也可以用 Map 對(duì)象。我們把兩個(gè)條件存成字符串。

// 優(yōu)化"例子🌰"

// 將判斷條件放入 Map 中
const actionsMap = new Map([
    ['administrator-1', '管理員喜歡王冰冰'],
    ['administrator-2', '管理員不喜歡王冰冰'],
    ['user-1', '用戶喜歡王冰冰'],
    ['user-2', '用戶不喜歡王冰冰']
]);

// 優(yōu)化后函數(shù)💎
const myFunction = (right, status) => {
    console.log(actionsMap.get(`${right}-${status}`));
};

2.4 將判斷條件放入 Object 后再放入 Map 中

// 優(yōu)化"例子🌰"

// 將判斷條件放入 Map 中
const actionsMap = new Map([
    [{ right: 'administrator', status: 1 }, () => console.log('管理員喜歡王冰冰')],
    [{ right: 'administrator', status: 2 }, () => console.log('管理員不喜歡王冰冰')],
    [{ right: 'user', status: 1 }, () => console.log('用戶喜歡王冰冰')],
    [{ right: 'user', status: 2 }, () => console.log('用戶不喜歡王冰冰')]
]);

// 優(yōu)化后函數(shù)💎
const myFunction = (right, status) => {
    const action = [...actionsMap].filter(([e]) => (e.right === right && e.status === status));
    action.forEach(([_, index]) => index.call());
};

2.5 將判斷條件寫成 正則 后再放入 Map 中

利用正則表達(dá)式可以處理相對(duì)復(fù)雜一點(diǎn)的情況。

// 優(yōu)化"有重復(fù)情況的例子🌰"

// 將判斷條件寫成 正則 后再放入 Map 中
const actions = () => {
    const f1 = () => console.log('管理員喜歡王冰冰');
    const f2 = () => console.log('用戶喜歡王冰冰');

    return new Map([
        [/^administrator-[1-2]/, f1],
        [/^user-[1-2]/, f2]
    ]);
};

// 優(yōu)化后函數(shù)💎
const myFunction = (right, status) => {
    const action = [...actions()].filter(([e]) => e.test(`${right}-${status}`));
    action.forEach(([_, index]) => index.call());
};

結(jié)語(yǔ)

我們利用原生 Object 和 Map 對(duì)象對(duì)判斷進(jìn)行了優(yōu)化,不過(guò)在真正的開(kāi)發(fā)過(guò)程中,我們還是要遵循 實(shí)用優(yōu)先 的原則,避免過(guò)度優(yōu)化。

到此這篇關(guān)于JavaScript中判斷的優(yōu)雅寫法的文章就介紹到這了,更多相關(guān)JavaScript判斷優(yōu)雅寫法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論