数组过滤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/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

发表回复

登录后才能评论