超碰人人人人人,亚洲AV午夜福利精品一区二区,亚洲欧美综合区丁香五月1区,日韩欧美亚洲系列

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

對(duì)象映射(Object Literal)和 Map 數(shù)據(jù)結(jié)構(gòu):拋棄 switch,讓JavaScript代碼更簡潔

admin
2025年5月5日 12:4 本文熱度 69

我們經(jīng)常需要根據(jù)不同的條件執(zhí)行不同的邏輯,傳統(tǒng)上,if-else 和 switch 語句是處理這類場景的常用方式。然而,隨著現(xiàn)代 JavaScript 的發(fā)展,出現(xiàn)了更優(yōu)雅、更簡潔的替代方案:對(duì)象映射(Object Literal)和 Map 數(shù)據(jù)結(jié)構(gòu)。

傳統(tǒng) switch 語句的問題

首先,讓我們看看傳統(tǒng) switch 語句的典型用法:

這種寫法存在幾個(gè)問題:

  1. 冗長且重復(fù) - 每個(gè) case 都需要寫 case 關(guān)鍵字和 return 或 break 語句
  2. 容易出錯(cuò) - 忘記 break 語句會(huì)導(dǎo)致意外的 fall-through 行為
  3. 難以維護(hù) - 添加或修改分支時(shí),需要在大塊代碼中仔細(xì)添加
  4. 可讀性較差 - 尤其當(dāng)每個(gè) case 分支包含較多邏輯時(shí)

使用對(duì)象映射(Object Literal)替代 switch

對(duì)象映射是替代簡單 switch 語句的最直接方式:

處理復(fù)雜邏輯

如果每個(gè)分支包含更復(fù)雜的邏輯,可以將函數(shù)作為對(duì)象的值:

使用 Map 數(shù)據(jù)結(jié)構(gòu)

ES6 引入的 Map 數(shù)據(jù)結(jié)構(gòu)提供了比對(duì)象字面量更強(qiáng)大的功能,特別適合以下場景:

  1. 鍵不限于字符串,可以是任何類型(包括對(duì)象、函數(shù)等)
  2. 需要頻繁添加/刪除鍵值對(duì)
  3. 需要保持插入順序
  4. 需要直接獲取映射的大小

用法示例

函數(shù)映射和鏈?zhǔn)讲僮?/span>

Map 非常適合實(shí)現(xiàn)命令模式或策略模式:

classCalculator {
  constructor() {
    this.operations = newMap([
      ['+'(a, b) => a + b],
      ['-'(a, b) => a - b],
      ['*'(a, b) => a * b],
      ['/'(a, b) => a / b],
      ['%'(a, b) => a % b],
      [''(a, b) => a  b]
    ]);
  }
  calculate(a, operator, b) {
    const operation = this.operations.get(operator);
    if (!operation) {
      throw new Error(`Unsupported operator: ${operator}`);
    }
    return operation(a, b);
  }
  // 擴(kuò)展計(jì)算器功能
  addOperation(operator, fn) {
    this.operations.set(operator, fn);
      return this// 支持鏈?zhǔn)秸{(diào)用
    }
  }

const calc = new Calculator()
  .addOperation('log'(a, b) =>Math.log(a) / Math.log(b));

console.log(calc.calculate(10'+'5)); // 15
console.log(calc.calculate(10'log'10)); // 1

現(xiàn)代 JavaScript 為我們提供了多種工具來改進(jìn)代碼質(zhì)量,擁抱對(duì)象映射和 Map,可以讓我們編寫出更優(yōu)雅、更易維護(hù)的代碼。

?

閱讀原文:原文鏈接


該文章在 2025/5/6 12:16:02 編輯過
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點(diǎn)晴ERP是一款針對(duì)中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對(duì)港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場、車隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場作業(yè)而開發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉儲(chǔ)管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲(chǔ)管理,倉庫管理,保質(zhì)期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號(hào)管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時(shí)間、不限用戶的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved