亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

你應該了解的JavaScript Array.map()五種用途小結

2024-05-06 16:46:48
字體:
來源:轉載
供稿:網友

前言

從經典的 for 循環到 forEach() 方法,用于迭代數據集合的各種技術和方法比比皆是。但是現在比較流行的方法是 .map() 方法。

.map() 通過指定函數調用一個數組中每一項元素,來創建一個新數組。 .map() 是一種 non-mutating(非變異) 方法,它創建一個新數組,而不是只對調用數組進行更改的 mutating(變異) 方法。這可能很難記住。

語法:

array.map(function(currentValue,index,arr), thisValue)
  • currentValue:必須。當前元素的值
  • index:可選。當期元素的索引值
  • arr:可選。當期元素屬于的數組對象
  • thisValue:可選。對象作為該執行回調時使用,傳遞給函數,用作 "this" 的值??筛淖僼his指向,

map() 方法返回一個新數組,數組中的元素為原始數組元素調用函數處理后的值。

map() 方法按照原始數組元素順序依次處理元素。

注意: map() 不會對空數組進行檢測。

注意: map() 不會改變原始數組。

在這篇文章中,我們將探討一下 JavaScript 中 .map() 的 4 個值得注意的用法。讓我們開始!

  • 在數組中的每一項元素上調用一個函數
  • 將字符串轉換為數組
  • 在 JavaScript 庫中用于渲染列表
  • 重新格式化數組對象
  • 小技巧使用案例

1. 在數組中的每一項元素上調用一個函數

如前所述,.map() 接受回調函數作為其參數之一,該函數的一個重要參數是由該函數處理的項的當前值。這是一個必需的參數。有了這個參數,我們可以修改數組中的每個單獨項,并在其上創建一個新元素。這里有一個例子:

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

我們可以看到,原數組 sweetArray 并沒有被修改,所以 .map() 是一種 non-mutating(非變異) 方法。這里值得一提的是 forEach() 方法,它是遍歷數組,對原來的數據操作,會改變原數組。

這甚至可以進一步簡化,使其更清潔:

// 創建一個要使用的函數const makeSweeter = sweetItem => sweetItem * 2;// 我們有一個數組const sweetArray = [2, 3, 4, 5, 35];// 調用我們制作的函數。更具可讀性const sweeterArray = sweetArray.map(makeSweeter);console.log(sweeterArray); // [4, 6, 8, 10, 70]

擁有像 sweetArray.map(makeSweeter) 這樣的代碼可以讓你在跳轉到這段代碼時更具可讀性。

2.將字符串轉換為數組

已知的 .map() 屬于 Array 原型。 我們如何使用它將字符串轉換為數組。 不用擔心,我們不需要再開發一個方法來處理字符串,而是使用特殊的 .call() 方法。

JavaScript 中的所有內容都是對象,方法只是附加到這些對象的函數。 .call() 允許我們利用另一個對象的上下文。 因此,我們將數組中的 .map() 上下文復制到字符串。

.call() 可以傳遞參數,要使用的上下文和“參數原始函數的參數”。 聽起來有點拗口? 這是一個例子:

const name = "Chuloo"const map = Array.prototype.mapconst newName = map.call(name, eachLetter => {return `${eachLetter}a`})console.log(newName) // ["Ca", "ha", "ua", "la", "oa", "oa"]

這里,我們只是在String上使用 .map() 的上下文,并傳遞了 .map() 所期望的函數參數。 你可以看看控制臺里打印出來的內容。

這類似于 String 的 .split() 方法,不過 .split() 方法只能在返回數組之前修改每個單獨的字符串字符。

3.在 JavaScript 庫中用于渲染列表

像 React 這樣的 JavaScript 庫利用 .map() 來渲染列表中的項目。這需要 JSX 語法,但是 .map() 方法包含在類似于 mustache 的 JSX 語法中。這是 React 組件的一個很好的例子。

import React from "react";import ReactDOM from "react-dom";const names = ["john", "sean", "mike", "jean", "chris"];const NamesList = () => (<div><ul>{names.map(name => <li key={name}> {name} </li>)}</ul></div>);const rootElement = document.getElementById("root");ReactDOM.render(<NamesList />, rootElement);

如果你不熟悉 React ,那么我告訴這是 React 中的一個簡單的無狀態組件,它使用列表渲染div。 使用 .map() 渲染單個列表項以迭代最初創建的 names 數組。 此組件使用 ReactDOM 渲染 ID為 root 的 DOM 元素 。

4.重新格式化數組對象

如何處理數組中的對象? .map() 可用于迭代數組中的對象,并以與傳統數組類似的方式,修改每個單獨對象的內容 并返回一個新數組。 這個修改是基于回調函數中返回的內容來完成的。這里有一個例子:

const myUsers = [{ name: 'chuloo', likes: 'grilled chicken' },{ name: 'chris', likes: 'cold beer' },{ name: 'sam', likes: 'fish biscuits' }]const usersByFood = myUsers.map(item => {const container = {};container[item.name] = item.likes;container.age = item.name.length * 10;return container;})console.log(usersByFood);// [{chuloo: "grilled chicken", age: 60}, {chris: "cold beer", age: 50}, {sam: "fish biscuits", age: 30}]

我們所做的就是使用括號和點符號簡單地修改數組中的每個對象。這個用例可以用于在前端應用程序上保存或解析之前處理或壓縮接收到的數據。

5.小技巧使用案例

通常情況下,.map() 方法中的 callback 函數只需要接受一個參數,就是正在被遍歷的數組元素本身。但這并不意味著 map 只給 callback 傳了一個參數。這個思維慣性可能會讓我們犯一個很容易犯的錯誤。 生成新數組元素的 callback 函數,有 三個參數:

  • currentValue – callback 的第一個參數,數組中正在處理的當前元素,最常用的參數。
  • index – callback 的第二個參數,數組中正在處理的當前元素的索引。
  • array – callback 的第三個參數,map 方法被調用的數組。

來看一下例子:

// 下面的語句返回什么呢:["1", "2", "3"].map(parseInt);// 你可能覺的會是[1, 2, 3]// 但實際的結果是 [1, NaN, NaN]// 通常使用parseInt時,只需要傳遞一個參數.// 但實際上,parseInt可以有兩個參數.第二個參數是進制數.// 可以通過語句"alert(parseInt.length)===2"來驗證.// map方法在調用callback函數時,會給它傳遞三個參數:當前正在遍歷的元素, // 元素索引, 原數組本身.// 第三個參數parseInt會忽視, 但第二個參數不會,也就是說,// parseInt把傳過來的索引值當成進制數來使用.從而返回了NaN.function returnInt(element) {return parseInt(element, 10);}['1', '2', '3'].map(returnInt); // [1, 2, 3]// 意料之中的結果// 也可以使用簡單的箭頭函數,結果同上['1', '2', '3'].map( str => parseInt(str) );// 一個更簡單的方式:['1', '2', '3'].map(Number); // [1, 2, 3]// 與`parseInt` 不同,下面的結果會返回浮點數或指數:['1.1', '2.2e2', '3e300'].map(Number); // [1.1, 220, 3e+300]

還有一個非常實用的小技巧,像 .map() ,.reduce(), .filter() 這些方法支持鏈式調用。例如:

var myArr = [ 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 ];var result = myArr.map(function(element) {// 數值大于5的數值視為5if (element > 5)return 5;return element;}).reduce(function(prev, element) {// 與之前的數值加總,回傳后代入下一輪的處理return prev + element;}, 0);// 40console.log(result);

這代碼看著有點啰嗦是吧?感謝 pythonicx 提供的優化代碼:

var myArr = [ 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 ];let result = myArr.map(m => m>5 ? 5 : m).reduce((x,y) => x+y);console.log(result); // 40

小結

在這篇文章中,我們研究了 JavaScript 中 .map() 方法的主要用途。 需要注意的是,與其他方法結合使用時,.map() 的函數可以得到強大的擴展和利用。 嘗試找出更多用例。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品揄拍500视频| 午夜精品久久久久久久99热| 国产精品偷伦视频免费观看国产| 国产精品精品视频| 国产精品第二页| 青青久久aⅴ北条麻妃| 欧美理论电影网| 韩国视频理论视频久久| 亚州欧美日韩中文视频| 欧美老女人xx| 亚洲精品日产aⅴ| 成人网欧美在线视频| 欧美成人午夜激情| 欧美在线免费观看| 成人啪啪免费看| 91日本在线视频| 日本韩国欧美精品大片卡二| 欧美亚洲第一页| 亚洲最大福利网站| 成人黄色免费网站在线观看| 亚洲白虎美女被爆操| 最新中文字幕亚洲| 久久成人精品一区二区三区| 亚洲第一区第二区| 久久久国产一区| 欧美另类极品videosbest最新版本| 亚洲日本中文字幕免费在线不卡| 亚洲国产成人久久综合一区| 国产国语刺激对白av不卡| 美女视频久久黄| 国产欧美一区二区三区在线| 久久99精品久久久久久青青91| 欧美日韩国产成人高清视频| 国产精品av免费在线观看| 亚洲一区二区三区毛片| 不卡在线观看电视剧完整版| 日韩欧美中文字幕在线观看| 久久久免费高清电视剧观看| 亚洲激情电影中文字幕| xvideos亚洲人网站| 欧美精品免费看| 欧美国产日韩一区| 国产精品自产拍在线观| 国产欧美欧洲在线观看| 国产精品免费一区二区三区都可以| 九九综合九九综合| 日韩电影中文字幕一区| 亚洲免费av网址| 亚洲精品一区二区网址| 久久精品美女视频网站| 久久免费成人精品视频| 一区二区三区黄色| 91成人免费观看网站| 成人亲热视频网站| 成人欧美一区二区三区在线湿哒哒| 国产精品v片在线观看不卡| 久久婷婷国产麻豆91天堂| 国产精品第七影院| 国产精品嫩草视频| 欧美电影免费观看高清完整| 伊人一区二区三区久久精品| 国产剧情久久久久久| 欧美视频中文在线看| 热久久这里只有精品| 欧美极品欧美精品欧美视频| 国模私拍视频一区| 久久久久久一区二区三区| 日韩国产一区三区| 亚洲第一中文字幕在线观看| 日韩精品一二三四区| 成人性生交xxxxx网站| 国产91精品久久久| 成人免费黄色网| 国产精品丝袜久久久久久高清| 日韩亚洲综合在线| 日本亚洲欧美三级| 国产97免费视| www.99久久热国产日韩欧美.com| 成人国产精品免费视频| 国产成人亚洲综合91| 九九九热精品免费视频观看网站| 亚洲精品色婷婷福利天堂| 日韩精品丝袜在线| 中文字幕亚洲欧美日韩在线不卡| 亚洲精品乱码久久久久久金桔影视| 欧美日韩另类在线| 中文字幕成人精品久久不卡| 久久久国产精彩视频美女艺术照福利| 性欧美在线看片a免费观看| 欧美激情亚洲一区| 午夜剧场成人观在线视频免费观看| 欧美多人爱爱视频网站| 红桃视频成人在线观看| 成人免费xxxxx在线观看| 亚洲一区二区三区视频播放| 欧美一区在线直播| 91久久精品美女高潮| 欧美美女15p| 亚洲网站在线播放| 国产有码一区二区| 国产一区二区三区18| 成人夜晚看av| 欧美激情国产精品| 精品国产一区二区三区在线观看| 黑人巨大精品欧美一区二区| 亚洲欧美激情在线视频| 国产女人18毛片水18精品| 日韩国产精品亚洲а∨天堂免| 91av在线网站| 国产丝袜精品第一页| 亚洲色无码播放| 亚洲精品在线观看www| 久久久久久久久久亚洲| 在线亚洲国产精品网| 欧美多人爱爱视频网站| 国产亚洲欧美视频| 国产精品十八以下禁看| 日韩av电影国产| 欧美中文在线观看| 亚洲在线第一页| 日韩欧美在线字幕| 久久久久久国产精品久久| 91久热免费在线视频| 国产日韩精品在线播放| 日韩在线观看成人| 日韩欧亚中文在线| 欧美电影免费观看| 亚洲亚裔videos黑人hd| 欧美日韩在线视频一区二区| 国产69精品久久久久9999| 97视频在线免费观看| 国产精品一区二区三区免费视频| 在线色欧美三级视频| 国产精品视频不卡| 精品久久久国产精品999| 久久久999国产精品| 亚洲成人黄色网址| 91高潮精品免费porn| 日韩精品免费在线| 欧美国产亚洲视频| 狠狠色香婷婷久久亚洲精品| 国产男女猛烈无遮挡91| 国产99久久精品一区二区 夜夜躁日日躁| 欧美一级视频免费在线观看| 色偷偷偷综合中文字幕;dd| 日韩一区二区久久久| 97在线精品视频| 在线观看欧美www| 欧美国产视频日韩| 欧美激情中文字幕乱码免费| 97国产精品视频人人做人人爱| 欧美成年人视频网站| 国产午夜精品全部视频在线播放| 成人精品视频在线| 午夜精品视频在线| 日韩av电影手机在线观看| 精品国内自产拍在线观看| 亚洲福利影片在线| 日韩亚洲在线观看| 蜜臀久久99精品久久久无需会员| 亚洲精品视频网上网址在线观看| 欧美大片大片在线播放| 欧美日韩在线看| 色悠悠国产精品|