搜尋
首頁web前端js教程如何使用 JavaScript 地圖 - .map()

從經典的 for 循環到 forEach() 方法,JavaScript 中使用了各種技術和方法來迭代數據集。最流行的方法之一是 .map() 方法。 .map() 通過對父數組中的每個項目調用特定函數來創建數組。 。地圖() 是一種非變異方法,它創建一個新的 js 數組,而不是 變異方法,僅對調用數組進行更改。

在處理數組時,此方法可以有很多用途。在本教程中,您將了解 .map() 的四個值得注意的用途 在 JavaScript 中:調用數組元素的函數,轉換字符串 數組、JavaScript 庫中的渲染列表以及重新格式化 數組對象。

截屏2025-01-13 10.17.53.png

如何為數組中的每個 Item 調用 JS 函數

.map() 接受回調函數 作為其參數之一,該函數的一個重要參數是 函數正在處理的項目的當前值。這是一個 所需參數。使用此參數,您可以修改項目中的每個項目 數組並將其作為新數組的修改成員返回。

以下是一個示例:

const sweetArray = [2, 3, 4, 5, 35]const sweeterArray = sweetArray.map(sweetItem => {
    return sweetItem * 2})console.log(sweeterArray)

此輸出被記錄到console:

Output[ 4, 6, 8, 10, 70 ]

這可以進一步簡化以使其更清晰:

// create a function to use
const makeSweeter = sweetItem => sweetItem * 2;
// we have an array
const sweetArray = [2, 3, 4, 5, 35];
// call the function we made. more readable
const sweeterArray = sweetArray.map(makeSweeter);
console.log(sweeterArray);

相同的輸出被記錄到console:

Output[ 4, 6, 8, 10, 70 ]

使用 sweetArray.map(makeSweeter) 這樣的代碼可以讓你的代碼更具可讀性。

如何將 JS 字符串轉換為數組

.map() 已知屬於數組原型。在 這一步您將使用它將字符串轉換為數組。你不是 在這裏開發適用於字符串的方法。相反,您將使用 特殊的 .call() 方法。

JavaScript 中的一切都是對象,方法是附加到這些對象的函數。 .call() 允許您在另一個對象上使用一個對象的上下文。因此,您可以將數組中的 .map() 上下文複製到字符串中。

.call() 可以傳遞要使用的上下文的參數以及原始函數參數的參數.

這是一個例如:

const name = "Sammy"
const map = Array.prototype.map
const newName = map.call(name, eachLetter => {
    return `${eachLetter}a`})
console.log(newName)

此輸出記錄到控製台:

Output[ "Sa", "aa", "ma", "ma", "ya" ]

在這裏,您使用了上下文.map() 在字符串上,並傳遞 .map() 期望的函數參數。

這與字符串的 .split() 方法類似,隻不過每個單獨的字符串字符都可以在之前修改以數組形式返回。

如何在 JavaScript 庫中渲染列表

像 React 這樣的 JavaScript 庫使用 .map() 來渲染 a 中的項目。 列表。然而,這需要 JSX 語法,因為 .map() 方法封裝在 JSX 語法中。

這是 React 組件的示例:

import React from "react";import ReactDOM from "react-dom";const names = ["whale", "squid", "turtle", "coral", "starfish"];const NamesList = () => (
  <div>
    <ul>{names.map(name => <li> {name} </li>)}</ul>
  </div>);const rootElement = document.getElementById("root");ReactDOM.render(<nameslist></nameslist>, rootElement);

這是一個無狀態的React 中的組件,它渲染一個帶有列表的 div。使用 .map() 迭代名稱數組來呈現各個列表項。該組件使用 ReactDOM 在 Id 為 root 的 DOM 元素上進行渲染。

如何重新格式化 JavaScript 數組對象

.map() 可用於迭代對象中的對象 數組,並以與傳統數組類似的方式修改 每個單獨對象的內容並返回一個新數組。這 根據回調函數返回的內容進行修改。

示例如下:

const myUsers = [
    { name: 'shark', likes: 'ocean' },
    { name: 'turtle', likes: 'pond' },
    { name: 'otter', likes: 'fish biscuits' }]const usersByLikes = myUsers.map(item => {
    const container = {};

    container[item.name] = item.likes;
    container.age = item.name.length * 10;

    return container;})console.log(usersByLikes);

此輸出被記錄到console:

Output[
    {shark: "ocean", age: 50},
    {turtle: "pond", age: 60},
    {otter: "fish biscuits", age: 50}
]

在這裏,您使用括號和點修改了數組中的每個對象 符號。該用例可用於處理或壓縮收到的 在前端應用程序上保存或解析之前的數據。


以上是如何使用 JavaScript 地圖 - .map()的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:digitalocean.com。如有侵權,請聯絡admin@php.cn刪除
JavaScript應用程序:從前端到後端JavaScript應用程序:從前端到後端May 04, 2025 am 12:12 AM

JavaScript可用於前端和後端開發。前端通過DOM操作增強用戶體驗,後端通過Node.js處理服務器任務。 1.前端示例:改變網頁文本內容。 2.後端示例:創建Node.js服務器。

Python vs. JavaScript:您應該學到哪種語言?Python vs. JavaScript:您應該學到哪種語言?May 03, 2025 am 12:10 AM

選擇Python還是JavaScript應基於職業發展、學習曲線和生態系統:1)職業發展:Python適合數據科學和後端開發,JavaScript適合前端和全棧開發。 2)學習曲線:Python語法簡潔,適合初學者;JavaScript語法靈活。 3)生態系統:Python有豐富的科學計算庫,JavaScript有強大的前端框架。

JavaScript框架:為現代網絡開發提供動力JavaScript框架:為現代網絡開發提供動力May 02, 2025 am 12:04 AM

JavaScript框架的強大之處在於簡化開發、提升用戶體驗和應用性能。選擇框架時應考慮:1.項目規模和復雜度,2.團隊經驗,3.生態系統和社區支持。

JavaScript,C和瀏覽器之間的關係JavaScript,C和瀏覽器之間的關係May 01, 2025 am 12:06 AM

引言我知道你可能會覺得奇怪,JavaScript、C 和瀏覽器之間到底有什麼關係?它們之間看似毫無關聯,但實際上,它們在現代網絡開發中扮演著非常重要的角色。今天我們就來深入探討一下這三者之間的緊密聯繫。通過這篇文章,你將了解到JavaScript如何在瀏覽器中運行,C 在瀏覽器引擎中的作用,以及它們如何共同推動網頁的渲染和交互。 JavaScript與瀏覽器的關係我們都知道,JavaScript是前端開發的核心語言,它直接在瀏覽器中運行,讓網頁變得生動有趣。你是否曾經想過,為什麼JavaScr

node.js流帶打字稿node.js流帶打字稿Apr 30, 2025 am 08:22 AM

Node.js擅長於高效I/O,這在很大程度上要歸功於流。 流媒體匯總處理數據,避免內存過載 - 大型文件,網絡任務和實時應用程序的理想。將流與打字稿的類型安全結合起來創建POWE

Python vs. JavaScript:性能和效率注意事項Python vs. JavaScript:性能和效率注意事項Apr 30, 2025 am 12:08 AM

Python和JavaScript在性能和效率方面的差異主要體現在:1)Python作為解釋型語言,運行速度較慢,但開發效率高,適合快速原型開發;2)JavaScript在瀏覽器中受限於單線程,但在Node.js中可利用多線程和異步I/O提升性能,兩者在實際項目中各有優勢。

JavaScript的起源:探索其實施語言JavaScript的起源:探索其實施語言Apr 29, 2025 am 12:51 AM

JavaScript起源於1995年,由布蘭登·艾克創造,實現語言為C語言。 1.C語言為JavaScript提供了高性能和系統級編程能力。 2.JavaScript的內存管理和性能優化依賴於C語言。 3.C語言的跨平台特性幫助JavaScript在不同操作系統上高效運行。

幕後:什麼語言能力JavaScript?幕後:什麼語言能力JavaScript?Apr 28, 2025 am 12:01 AM

JavaScript在瀏覽器和Node.js環境中運行,依賴JavaScript引擎解析和執行代碼。 1)解析階段生成抽象語法樹(AST);2)編譯階段將AST轉換為字節碼或機器碼;3)執行階段執行編譯後的代碼。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

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

熱工具

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。