數組過濾filter

一、基本介紹

數組過濾是指根據特定條件從數組中篩選出符合條件的元素形成新數組,這個過程就是數組過濾。在JavaScript中,可以使用filter()方法完成數組過濾的操作。

此方法創建一個新的數組,其包含通過給定函數實現的測試的所有元素。

filter()方法不會改變原始數組

    const array = [1, 2, 3, 4, 5];
    const newArray = array.filter(element => element > 3);
    console.log(newArray);// [4,5]>

二、基本語法

filter()方法有兩個參數,分別是回調函數和可選參數this。回調函數一共接受三個參數:

  1. 數組當前項的值
  2. 當前項的下標
  3. 當前操作的數組

回調函數必須返回一個布爾類型。如果為true,則保留該項並將其添加到新的輸出數組中,如果為false,則刪除該項。

    var new_array = arr.filter(callback(element[, index[, array]])[, thisArg])

三、常見操作

1.filter()方法實現數字去重

數組去重是一項經常需要完成的操作,JS中使用filter()方法可以快速去重一個數字數組,比如使用 Set() 方法也可以實現去重,但filter()方法更方便易用。

    const numbers = [1,2,2,3,4,4,5];
    let uniqueNumbers = numbers.filter((value, index, array) => array.indexOf(value) === index);
    console.log(uniqueNumbers); // [1, 2, 3, 4, 5]

2.filter()方法實現對象數組條件過濾

objects數組是一個具有結構化數據的對象數組。可以使用filter方法對此類型的數組進行過濾。

從對象數組中獲取符合特定屬性值的對象,只需在回調內對該值進行比較即可完成對象數組的篩選。

    const users = [
        { id: 1, name: 'Alex', age: 27 },
        { id: 2, name: 'Max', age: 20 },
        { id: 3, name: 'Jack', age: 25 }
    ];
    const result = users.filter(user => user.age > 23);
    console.log(result);// [{ id: 1, name: 'Alex', age: 27 }, { id: 3, name: 'Jack', age: 25 }]

3.filter()方法實現模糊關鍵字過濾

filter還可以根據數組元素中的字元進行模糊過濾,比如刪除名字中包含某個字元的對象。這個技巧很有用,因為你不一定總能確切的知道要篩選的值。

    const fruits = ['apple', 'banana', 'citrus', 'peach', 'grape'];
    const result = fruits.filter(fruit => fruit.includes('a'));
    console.log(result);// ['apple', 'banana', 'grape']

四、結束語

使用filter()方法能快速方便的對數組進行過濾操作,我們可以根據需要自由的組合使用filter()方法來實現複雜的需求。

本篇文章介紹到常見操作,可能還有一些不常見的用法,需要動手實踐多多嘗試。

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

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-11-24 06:18
下一篇 2024-11-24 06:19

相關推薦

  • Python導入數組

    本文將為您詳細闡述Python導入數組的方法、優勢、適用場景等方面,並附上代碼示例。 一、numpy庫的使用 numpy是Python中一個強大的數學庫,其中提供了非常豐富的數學函…

    編程 2025-04-29
  • Python返回數組:一次性搞定多種數據類型

    Python是一種多用途的高級編程語言,具有高效性和易讀性的特點,因此被廣泛應用於數據科學、機器學習、Web開發、遊戲開發等各個領域。其中,Python返回數組也是一項非常強大的功…

    編程 2025-04-29
  • Python去掉數組的中括弧

    在Python中,被中括弧包裹的數據結構是列表,列表是Python中非常常見的數據類型之一。但是,有些時候我們需要將列表展開成一維的數組,並且去掉中括弧。本文將為大家詳細介紹如何用…

    編程 2025-04-29
  • Python操作數組

    本文將從多個方面詳細介紹如何使用Python操作5個數組成的列表。 一、數組的定義 數組是一種用於存儲相同類型數據的數據結構。Python中的數組是通過列表來實現的,列表中可以存放…

    編程 2025-04-29
  • Python二維數組對齊輸出

    本文將從多個方面詳細闡述Python二維數組對齊輸出的方法與技巧。 一、格式化輸出 Python中提供了格式化輸出的方法,可以對輸出的字元串進行格式化處理。 names = [‘A…

    編程 2025-04-29
  • Java創建一個有10萬個元素的數組

    本文將從以下方面對Java創建一個有10萬個元素的數組進行詳細闡述: 一、基本介紹 Java是一種面向對象的編程語言,其強大的數組功能可以支持創建大規模的多維數組以及各種複雜的數據…

    編程 2025-04-28
  • Python數組隨機分組用法介紹

    Python數組隨機分組是一個在數據分析與處理中常用的技術,它可以將一個大的數據集分成若干組,以便於進行處理和分析。本文將從多個方面對Python數組隨機分組進行詳細的闡述,包括使…

    編程 2025-04-28
  • Python數組索引位置用法介紹

    Python是一門多用途的編程語言,它有著非常強大的數據處理能力。數組是其中一個非常重要的數據類型之一。Python支持多種方式來操作數組的索引位置,我們可以從以下幾個方面對Pyt…

    編程 2025-04-28
  • Python語言數組從大到小排序符號的用法介紹

    當我們使用Python進行編程的時候,經常需要對數組進行排序從而使數組更加有序,而數組的排序方式有很多,其中從大到小排序符號是一種常見的排序方式。本文將從多個方面對Python語言…

    編程 2025-04-28
  • 如何使用integratecustomerdata.stream().filter(c->{ if (collectionutil.isnotempty(

    本文將詳細介紹如何在Java編程中使用integratecustomerdata.stream().filter(c->{ if (collectionutil.isnote…

    編程 2025-04-28

發表回復

登錄後才能評論