JavaScript 陣列:地圖
Map 函數:一對一資料轉換
有時需要修改資料以傳回其一部分或執行一致的操作,這就是 映射。
方法 | 返回值 | 一对一 | 对所有元素运行 |
---|---|---|---|
.map((value, index, array) => *) | 数组 | 是 | 是 |
每當需要為每個輸入產生一個輸出時,map
通常是首選方法。它接受一個 映射 函數,該函數對每個記錄進行操作。映射函數傳回的值將出現在新數組中,其位置與原始值相同。
從 for 迴圈到 .map()
.map()
與基本的 for 迴圈完美匹配。
例如,需要將以下數組中的所有元素轉換為大寫字母:
const data = ['a', 'b', 'c', 'd'];
以下是幾種實作方式:
// 旧的命令式方法 - for 循环 function mapToUpper(data) { const newData = new Array(data.length); for (let i = 0; i < data.length; i++) { newData[i] = data[i].toUpperCase(); } return newData; } // 新的命令式方法 - for...of 循环 function mapToUpper(data) { const newData = []; for (let value of data) { newData.push(value.toUpperCase()); } return newData; } // 新的声明式方法 - .map() const mapToUpper = (data) => data.map(value => value.toUpperCase());
一些變體,例如 `const newData = new Array(data.length)` 與 `const newData = []`,並非由不同的循環類型強制要求,而是代表了一些歷史上的編碼風格差異。
用例
資料轉換
`.map()` 的常見用途包括從物件中取得值或對資料執行一致的變更或 *轉換*。
通常需要從每個較大的記錄中獲取一條資訊。 `map` 正是為此而設計的。
const data = [{ name: 'Alec Berg', roles: ['Creator', 'Executive Producer'], }, { name: 'Bill Hader', roles: ['Creator', 'Executive Producer', 'Actor', 'Director'], }]; // 只需要姓名 data.map((entry) => entry.name); // [ 'Alec Berg', 'Bill Hader' ]
如果需要對訂單提供員工折扣,`map` 也能做到!
const cart = [{ itemId: 12345, name: 'shoes', price: 70.00, },{ itemId: 54321, name: 'shirt', price: 15.25, }]; // 应用折扣 const applyDiscount = (discountPercent, order) => { // 首先,获取“剩余”金额。 // 如果折扣为 10%,则乘数为 0.9 const multiplier = 1 - (discountPercent / 100); // 为每个项目创建一个新条目,其中包含折扣后的价格。 // 我们将包含旧价格以供参考。 return order.map((item) => ({ ...item, price: item.price * multiplier, originalPrice: item.price, })); };
此處未給出輸出結果。如果您想自己嘗試,建議將其貼上到瀏覽器控制台或 RunJS 等工具中,我使用該工具編寫和測試這些範例。
遞增
這是資料轉換的一個特殊版本。從「無資訊」開始,但擁有陣列此行為為每個條目提供了 *索引*,並且可以透過新增 1 將索引(從零開始)轉換為計數數字。
不需要使用 `value`(提供給 *映射* 函數的第一個參數),但必須為其提供一個名稱才能存取第二個參數。底線字元是一個有效的變數名,通常用於表示不需要的值,就像在本例中一樣。
const getCountingNumbers = (upTo) => new Array(upTo) // 新数组是“稀疏的”,需要值才能映射 .fill('') // 第二个参数是数组索引。 .map((_, index) => index + 1); getCountingNumbers(5); // [ 1, 2, 3, 4, 5 ]
雖然這是一個 `.map()` 的範例,但較新的函數也可以執行此操作:`Array.from()`。
const getCountingNumbers = (upTo) => Array.from( // 通过提供具有长度的对象来“伪造”类似数组的对象 { length: upTo }, // 使用与 .map() 相同的映射函数。 (_, index) => index + 1 );
在使用 `.map()` 時討論另一種方法似乎很奇怪,但在幕後,`Array.from()` 至少會為上面的範例呼叫 `.map()`。
總結
希望這能幫助您了解如何使用 `.map()`。資料轉換是許多工具和產業的核心,因此 `.map()` 是許多專案中的關鍵部分。
如果您對 `.map()` 有任何問題或意見,我很樂意討論!
以上是JavaScript 陣列:地圖的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

JavaScript是現代Web開發的基石,它的主要功能包括事件驅動編程、動態內容生成和異步編程。 1)事件驅動編程允許網頁根據用戶操作動態變化。 2)動態內容生成使得頁面內容可以根據條件調整。 3)異步編程確保用戶界面不被阻塞。 JavaScript廣泛應用於網頁交互、單頁面應用和服務器端開發,極大地提升了用戶體驗和跨平台開發的靈活性。

Python和JavaScript開發者的薪資沒有絕對的高低,具體取決於技能和行業需求。 1.Python在數據科學和機器學習領域可能薪資更高。 2.JavaScript在前端和全棧開發中需求大,薪資也可觀。 3.影響因素包括經驗、地理位置、公司規模和特定技能。

實現視差滾動和元素動畫效果的探討本文將探討如何實現類似資生堂官網(https://www.shiseido.co.jp/sb/wonderland/)中�...

JavaScript的最新趨勢包括TypeScript的崛起、現代框架和庫的流行以及WebAssembly的應用。未來前景涵蓋更強大的類型系統、服務器端JavaScript的發展、人工智能和機器學習的擴展以及物聯網和邊緣計算的潛力。

如何在JavaScript中將具有相同ID的數組元素合併到一個對像中?在處理數據時,我們常常會遇到需要將具有相同ID�...

不同JavaScript引擎在解析和執行JavaScript代碼時,效果會有所不同,因為每個引擎的實現原理和優化策略各有差異。 1.詞法分析:將源碼轉換為詞法單元。 2.語法分析:生成抽象語法樹。 3.優化和編譯:通過JIT編譯器生成機器碼。 4.執行:運行機器碼。 V8引擎通過即時編譯和隱藏類優化,SpiderMonkey使用類型推斷系統,導致在相同代碼上的性能表現不同。

探索前端中類似VSCode的面板拖拽調整功能的實現在前端開發中,如何實現類似於VSCode...
