亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript中map()和filter()的使用區(qū)別

 更新時(shí)間:2025年05月08日 10:24:44   作者:胡歌1  
map()和filter()都是 JavaScript數(shù)組的高階函數(shù),本文主要介紹了JavaScript中map()和filter()的使用區(qū)別,具有一定的參考價(jià)值,感興趣的可以了解一下

map() 和 filter() 都是 JavaScript 數(shù)組的高階函數(shù),但它們的用途和行為有本質(zhì)區(qū)別:

核心區(qū)別對(duì)比表

特性map()filter()
用途轉(zhuǎn)換數(shù)組元素篩選數(shù)組元素
返回值新數(shù)組(與原數(shù)組長度相同)新數(shù)組(長度≤原數(shù)組)
回調(diào)返回要求返回轉(zhuǎn)換后的元素返回布爾值(決定是否保留元素)
空位處理保留空位(返回undefined)跳過空位
是否修改原數(shù)組不修改原數(shù)組(純函數(shù))不修改原數(shù)組(純函數(shù))

代碼示例對(duì)比

示例數(shù)組

const numbers = [1, 2, 3, 4, 5];
const users = [
  { id: 1, name: 'Alice', active: true },
  { id: 2, name: 'Bob', active: false },
  { id: 3, name: 'Charlie', active: true }
];

map() 示例

// 將每個(gè)數(shù)字平方
const squares = numbers.map(n => n * n);
console.log(squares); // [1, 4, 9, 16, 25]

// 提取用戶名數(shù)組
const names = users.map(user => user.name);
console.log(names); // ['Alice', 'Bob', 'Charlie']

// 處理空位
const sparse = [1, , 3];
const mapped = sparse.map(x => x * 2);
console.log(mapped); // [2, , 6]

filter() 示例

// 篩選偶數(shù)
const evens = numbers.filter(n => n % 2 === 0);
console.log(evens); // [2, 4]

// 篩選活躍用戶
const activeUsers = users.filter(user => user.active);
console.log(activeUsers); 
// [{id:1,name:'Alice',active:true}, {id:3,name:'Charlie',active:true}]

// 處理空位
const sparse = [1, , 3];
const filtered = sparse.filter(x => true);
console.log(filtered); // [1, 3] (空位被跳過)

關(guān)鍵區(qū)別詳解

1. 用途不同

map() 用于 轉(zhuǎn)換/映射 數(shù)組元素

// 將溫度從攝氏度轉(zhuǎn)換為華氏度
const celsius = [0, 10, 20];
const fahrenheit = celsius.map(c => c * 9/5 + 32);
console.log(fahrenheit); // [32,50,68]

filter() 用于 篩選 數(shù)組元素

// 篩選正數(shù)
const temps = [-2, 5, -10, 15];
const positiveTemps = temps.filter(t => t > 0);
console.log(positiveTemps); //[5,15]

2. 返回值不同

map() 總是返回 等長數(shù)組

[1, 2, 3].map(x => x * 2); // [2, 4, 6] (長度保持3)

filter() 返回 可能更短的數(shù)組

[1, 2, 3].filter(x => x > 1); // [2, 3] (長度變?yōu)?)

3. 回調(diào)函數(shù)要求不同

map() 回調(diào)返回 任意類型值

[1, 2].map(x => ({ value: x })); // 返回對(duì)象數(shù)組:  [{value:1}, {value:2}]

filter() 回調(diào)必須返回 布爾值

[1, 2].filter(x => x % 2 === 0); // 必須返回true/false // [2]

組合使用示例

兩者常結(jié)合使用實(shí)現(xiàn)復(fù)雜邏輯:

// 獲取所有活躍用戶的名字
const activeNames = users
  .filter(user => user.active)    // 先篩選
  .map(user => user.name);        // 再轉(zhuǎn)換
console.log(activeNames);         // ['Alice', 'Charlie']

// 計(jì)算所有正數(shù)的平方根
const numbers = [4, -1, 9, -5, 16];
const positiveRoots = numbers
  .filter(n => n > 0)            // 篩選正數(shù)
  .map(n => Math.sqrt(n));       // 計(jì)算平方根
console.log(positiveRoots );     // [2, 3, 4]

性能注意事項(xiàng)

map() 總會(huì)遍歷所有元素

filter() 也總會(huì)遍歷所有元素

當(dāng)鏈?zhǔn)秸{(diào)用時(shí),考慮順序優(yōu)化:

// 更高效的寫法:先篩選再轉(zhuǎn)換(減少map操作次數(shù))
bigArray.filter(x => x > 10).map(x => x * 2);

// 低效寫法(會(huì)先對(duì)所有元素執(zhí)行轉(zhuǎn)換)
bigArray.map(x => x * 2).filter(x => x > 20);

特殊場(chǎng)景處理

處理稀疏數(shù)組

const sparse = [1, , , 4];

// map會(huì)保留空位
const mapSparse = sparse.map(x => x * 2); 
console.log(mapSparse); // [2, , , 8]

// filter會(huì)跳過空位
const filterSparse =sparse.filter(x => true); 
console.log(filterSparse); // [1, 4]

處理數(shù)組中的假值

const mixed = [0, 1, false, 2, '', 3];

// filter可以用于移除假值
const truths = mixed.filter(Boolean); // [1, 2, 3]

總結(jié)選擇指南

  • 需要 轉(zhuǎn)換每個(gè)元素 → 用 map()

  • 需要 基于條件篩選元素 → 用 filter()

  • 需要 既篩選又轉(zhuǎn)換 → 組合使用(通常先filter后map)

  • 需要 保持?jǐn)?shù)組長度 → 只能用 map()

  • 需要 移除特定元素 → 用 filter()

 到此這篇關(guān)于JavaScript中map()和filter()的使用區(qū)別的文章就介紹到這了,更多相關(guān)JavaScript map()和filter()內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 淺談js的html元素的父節(jié)點(diǎn),子節(jié)點(diǎn)

    淺談js的html元素的父節(jié)點(diǎn),子節(jié)點(diǎn)

    下面小編就為大家?guī)硪黄獪\談js的html元素的父節(jié)點(diǎn),子節(jié)點(diǎn)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-08-08
  • 微信小程序自定義膠囊樣式

    微信小程序自定義膠囊樣式

    這篇文章主要為大家詳細(xì)介紹了微信小程序自定義膠囊樣式,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • JS實(shí)現(xiàn)JSON.stringify的實(shí)例代碼講解

    JS實(shí)現(xiàn)JSON.stringify的實(shí)例代碼講解

    JSON.stringify是瀏覽器高版本帶的一個(gè)將JS的Objtect對(duì)象轉(zhuǎn)換為JSON字符串的一個(gè)方法,不過再IE6下面,并不存在JSON這一對(duì)象,因此,用到此方法時(shí),需要寫一套兼容性的代碼。接下來通過本文給大家分享JS實(shí)現(xiàn)JSON.stringify的實(shí)例代碼,需要的朋友參考下吧
    2017-02-02
  • 將html頁面保存成圖片,圖片寫入pdf的實(shí)現(xiàn)方法(推薦)

    將html頁面保存成圖片,圖片寫入pdf的實(shí)現(xiàn)方法(推薦)

    下面小編就為大家?guī)硪黄獙tml頁面保存成圖片,圖片寫入pdf的實(shí)現(xiàn)方法(推薦)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-09-09
  • 原生JS實(shí)現(xiàn)日歷組件的示例代碼

    原生JS實(shí)現(xiàn)日歷組件的示例代碼

    本篇文章主要介紹了原生JS實(shí)現(xiàn)日歷組件的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-09-09
  • 關(guān)于JS中一維數(shù)組和二維數(shù)組互轉(zhuǎn)問題

    關(guān)于JS中一維數(shù)組和二維數(shù)組互轉(zhuǎn)問題

    這篇文章主要介紹了js中一維數(shù)組和二維數(shù)組互轉(zhuǎn),本文結(jié)合示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-04-04
  • js實(shí)現(xiàn)前端圖片上傳即時(shí)預(yù)覽功能

    js實(shí)現(xiàn)前端圖片上傳即時(shí)預(yù)覽功能

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)前端圖片即時(shí)預(yù)覽功能,本地預(yù)覽功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • js實(shí)現(xiàn)圖片上傳并預(yù)覽功能

    js實(shí)現(xiàn)圖片上傳并預(yù)覽功能

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)圖片上傳并預(yù)覽功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-08-08
  • js中異步函數(shù)async function變同步函數(shù)的簡(jiǎn)單入門

    js中異步函數(shù)async function變同步函數(shù)的簡(jiǎn)單入門

    這篇文章主要介紹了js中異步函數(shù)async function變同步函數(shù)的簡(jiǎn)單入門,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • JavaScript的高級(jí)概念和用法詳解

    JavaScript的高級(jí)概念和用法詳解

    JavaScript語言不斷發(fā)布一些新特性,感覺要上天的節(jié)奏啊。本文搜集整理了一些它的高級(jí)概念和用法,需要的朋友可以參考下
    2022-07-07

最新評(píng)論