深入淺出:從多個方面詳解map函數JS

一、基本使用方法

//ES5
var arr = [1,2,3,4];
var newArr = arr.map(function(item){
  return item * 2;
})
console.log(newArr); // [2,4,6,8]

//ES6
let arr = [1,2,3,4];
let newArr = arr.map(item => item * 2);
console.log(newArr); // [2,4,6,8]

map函數是JavaScript Array的方法之一。作用是對數組中的每一項進行處理後,返回一個新的數組。

基本語法:array.map(callback(currentValue[, index[, array]])

其中callback表示一個函數,可以有三個參數:currentValue表示當前正在處理的元素,index表示當前正在處理的元素的索引,array表示原數組。其中currentIndex和array是可選的參數。

二、高級使用方法

1、實現數組去重

let arr = [1,2,2,3,3,3,4,4,4,4],
    newArr = arr.sort((a,b)=>a-b).map((v, i, self) => {
        if(i == 0){
            return v;
        }else{
            if(v !== self[i-1]){
                return v;
            }
        }
    }).filter(v => v);
console.log(newArr); //[1,2,3,4]

代碼原理:先將數組排序,然後通過map方法,如果當前元素不等於前一個,則返回當前元素,最後通過filter方法過濾掉undefined。

2、通過map實現一些常見的數組方法

//forEach
function forEach(arr, cb){
  for(let i=0;i<arr.length;i++){
    cb(arr[i],i,arr);
  }
}
//map
function map(arr, cb){
  let res = [];
  for(let i=0;i<arr.length;i++){
    res.push(cb(arr[i],i,arr));
  }
  return res;
}
//filter
function filter(arr, cb){
  let res = [];
  for(let i=0;i item * 2);
console.log(newArr); //[2,4,6,8]

代碼原理:通過自定義forEach,map,filter方法實現類似於它們的功能,同時使用map方法使代碼更加簡潔。

三、使用場景

1、數據展示

let arr = [
  {
    name: 'Tom',
    age: 18
  },
  {
    name: 'Jerry',
    age: 20
  }
];
let nameArr = arr.map((obj) => obj.name);
console.log(nameArr); //['Tom','Jerry']

代碼原理:通過map方法,將數組中每一個對象中的name屬性提取出來,生成一個新的數組。

2、數組操作

let arr = [1,2,3,4],
    newArr = arr.map((item) => item * 2);
console.log(newArr); //[2,4,6,8]

代碼原理:通過map方法,將數組中的每一個元素都乘以2,生成一個新的數組。

3、字符串處理

let arr = [' apple ', ' banana ', ' pear '],
    trimArr = arr.map((item) => item.trim());
console.log(trimArr); // ['apple', 'banana', 'pear']

代碼原理:通過map方法,將數組中的每個字符串都去除空格,生成一個新的數組。

4、生成HTML元素

let arr = ['apple','banana','pear'],
    htmlArr = arr.map(item => `
  • ${item}
  • `).join(''); console.log(`
      ${htmlArr}
    `); //
    • apple
    • banana
    • pear

    代碼原理:通過map方法生成一個新的數組,其中每個元素都是一個li元素字符串。最後通過join方法將字符串數組拼接成一個完整的ul元素字符串。

    四、總結

    map函數是JavaScript中常用的高階函數,通過它可以簡化很多數組的操作。使用map方法不僅可以快速地生成新的數組,也可以實現一些常見的數組方法功能。同時它也可以用於各種場景,比如數據展示,數組操作,字符串處理和生成HTML元素等等。

    原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/298113.html

    (0)
    打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
    小藍的頭像小藍
    上一篇 2024-12-28 12:17
    下一篇 2024-12-28 12:17

    相關推薦

    • Python中引入上一級目錄中函數

      Python中經常需要調用其他文件夾中的模塊或函數,其中一個常見的操作是引入上一級目錄中的函數。在此,我們將從多個角度詳細解釋如何在Python中引入上一級目錄的函數。 一、加入環…

      編程 2025-04-29
    • Python中capitalize函數的使用

      在Python的字符串操作中,capitalize函數常常被用到,這個函數可以使字符串中的第一個單詞首字母大寫,其餘字母小寫。在本文中,我們將從以下幾個方面對capitalize函…

      編程 2025-04-29
    • 為什麼Python不能編譯?——從多個方面淺析原因和解決方法

      Python作為很多開發人員、數據科學家和計算機學習者的首選編程語言之一,受到了廣泛關注和應用。但與之伴隨的問題之一是Python不能編譯,這給基於編譯的開發和部署方式帶來不少麻煩…

      編程 2025-04-29
    • Python中set函數的作用

      Python中set函數是一個有用的數據類型,可以被用於許多編程場景中。在這篇文章中,我們將學習Python中set函數的多個方面,從而深入了解這個函數在Python中的用途。 一…

      編程 2025-04-29
    • 單片機打印函數

      單片機打印是指通過串口或並口將一些數據打印到終端設備上。在單片機應用中,打印非常重要。正確的打印數據可以讓我們知道單片機運行的狀態,方便我們進行調試;錯誤的打印數據可以幫助我們快速…

      編程 2025-04-29
    • 三角函數用英語怎麼說

      三角函數,即三角比函數,是指在一個銳角三角形中某一角的對邊、鄰邊之比。在數學中,三角函數包括正弦、餘弦、正切等,它們在數學、物理、工程和計算機等領域都得到了廣泛的應用。 一、正弦函…

      編程 2025-04-29
    • Python3定義函數參數類型

      Python是一門動態類型語言,不需要在定義變量時顯示的指定變量類型,但是Python3中提供了函數參數類型的聲明功能,在函數定義時明確定義參數類型。在函數的形參後面加上冒號(:)…

      編程 2025-04-29
    • Java判斷字符串是否存在多個

      本文將從以下幾個方面詳細闡述如何使用Java判斷一個字符串中是否存在多個指定字符: 一、字符串遍歷 字符串是Java編程中非常重要的一種數據類型。要判斷字符串中是否存在多個指定字符…

      編程 2025-04-29
    • Python定義函數判斷奇偶數

      本文將從多個方面詳細闡述Python定義函數判斷奇偶數的方法,並提供完整的代碼示例。 一、初步了解Python函數 在介紹Python如何定義函數判斷奇偶數之前,我們先來了解一下P…

      編程 2025-04-29
    • Python合併多個相同表頭文件

      對於需要合併多個相同表頭文件的情況,我們可以使用Python來實現快速的合併。 一、讀取CSV文件 使用Python中的csv庫讀取CSV文件。 import csv with o…

      編程 2025-04-29

    發表回復

    登錄後才能評論