JS数组过滤filter详解

一、JS数组过滤方法

在js中,数组是一个非常重要的数据类型,它可以存储多个数据项,并且可以通过下标来访问每个数据项。在实际应用中,我们常常需要对数组进行筛选,只留下符合条件的数据项。这时候,就需要用到js中的数组过滤方法filter。

数组过滤方法filter的语法如下:

array.filter(callback[, thisArg]);

其中,array是要进行筛选的数组;callback是用于测试每个元素的函数,同时该函数还可以接收三个参数:当前元素、当前元素的索引、原数组。thisArg是可选参数,代表在执行callback函数时使用的this值。该方法将返回一个符合条件的新数组。

二、JS数组过滤对象

在js中,数组的每个元素可以是任意的数据类型,包括对象。如果我们要对一个包含多个对象的数组进行筛选,可以使用filter配合箭头函数进行操作。

例如,我们有一个包含多个人员信息的数组,我们要筛选出18岁以下的人员信息。代码如下:

const people = [
  {name: "Tom", age: 20},
  {name: "Jerry", age: 17},
  {name: "John", age: 15},
  {name: "Mary", age: 19}
];

const under18s = people.filter(person => person.age < 18);

console.log(under18s);
// Output: [{name: "Jerry", age: 17}, {name: "John", age: 15}]

三、数组过滤JS

在进行数组过滤时,我们不仅可以使用箭头函数,还可以使用普通函数来进行筛选。例如,我们有一个包含多个整数的数组,我们要筛选出大于等于10的整数。代码如下:

const nums = [8, 10, 5, 12, 3];

function filterNum(num) {
  return num >= 10;
}

const result = nums.filter(filterNum);

console.log(result);
// Output: [10, 12]

四、JS数组过滤返回新数组

在使用数组过滤方法filter时,原数组不会发生改变,而是返回一个符合条件的新数组。例如,我们有一个包含多个整数的数组,我们要筛选出大于等于10的整数,并将原数组输出。代码如下:

const nums = [8, 10, 5, 12, 3];

function filterNum(num) {
  return num >= 10;
}

const result = nums.filter(filterNum);

console.log(nums);
console.log(result);
// Output: [8, 10, 5, 12, 3]
// Output: [10, 12]

五、JS数组过滤取值

在使用数组过滤方法filter时,我们不仅可以进行数据筛选,还可以取出符合条件的数据项中的某个值。例如,我们有一个包含多个人员信息的数组,我们要取出18岁以下的人员的姓名。代码如下:

const people = [
  {name: "Tom", age: 20},
  {name: "Jerry", age: 17},
  {name: "John", age: 15},
  {name: "Mary", age: 19}
];

const under18sName = people
  .filter(person => person.age  person.name);

console.log(under18sName);
// Output: ["Jerry", "John"]

六、JS数组过滤重复

在使用数组过滤方法filter时,我们还可以去重。例如,我们有一个包含多个整数的数组,其中存在重复的元素,我们要去除重复的元素并输出。代码如下:

const nums = [1, 2, 3, 4, 3, 2, 1];

const uniqueNums = nums.filter((num, idx, arr) => arr.indexOf(num) === idx);

console.log(uniqueNums);
// Output: [1, 2, 3, 4]

上面的代码中,我们通过调用数组方法indexOf来判断当前元素是否第一次出现,如果是,就将其加入到新数组中。

七、JS数组过滤掉某一项

在使用数组过滤方法filter时,我们还可以将指定的元素从数组中剔除。例如,我们有一个包含多个人员信息的数组,我们要剔除姓名为Jerry的人员信息。代码如下:

const people = [
  {name: "Tom", age: 20},
  {name: "Jerry", age: 17},
  {name: "John", age: 15},
  {name: "Mary", age: 19}
];

const filteredPeople = people.filter(person => person.name !== "Jerry");

console.log(filteredPeople);
// Output: [{name: "Tom", age: 20}, {name: "John", age: 15}, {name: "Mary", age: 19}]

八、JS数组过滤空字符串

在进行数组过滤时,我们经常要处理空字符串的情况。例如,我们有一个包含多个字符串的数组,其中某些元素为空字符串,我们要将其过滤掉并输出。代码如下:

const strs = ["abc", "", "def", "", "ghi"];

const filteredStrs = strs.filter(str => str !== "");

console.log(filteredStrs);
// Output: ["abc", "def", "ghi"]

九、JS数组过滤空值

在进行数组过滤时,我们还要考虑null、undefined等空值的情况。例如,我们有一个包含多个元素的数组,其中某些元素为null或undefined,我们要将其过滤掉并输出。代码如下:

const arr = ["abc", null, "def", undefined, "ghi"];

const filteredArr = arr.filter(item => item);

console.log(filteredArr);
// Output: ["abc", "def", "ghi"]

十、JS数组过滤器选取

JS数组过滤器是一个十分强大的工具,它可以帮助我们从一个数组中选择满足特定条件的元素,并返回一个新数组。通过本篇文章,我们了解了JS数组过滤方法的基本语法以及多种应用场景,希望对大家在实际开发中有所帮助。

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/153454.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝的头像小蓝
上一篇 2024-11-14 03:05
下一篇 2024-11-14 03:05

相关推荐

  • JS Proxy(array)用法介绍

    JS Proxy(array)可以说是ES6中非常重要的一个特性,它可以代理一个数组,监听数据变化并进行拦截、处理。在实际开发中,使用Proxy(array)可以方便地实现数据的监…

    编程 2025-04-29
  • 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
  • 解析js base64并转成unit

    本文将从多个方面详细介绍js中如何解析base64编码并转成unit格式。 一、base64编码解析 在JavaScript中解析base64编码可以使用atob()函数,它会将b…

    编程 2025-04-29
  • Node.js使用Body-Parser处理HTTP POST请求时,特殊字符无法返回的解决方法

    本文将解决Node.js使用Body-Parser处理HTTP POST请求时,特殊字符无法返回的问题。同时,给出一些相关示例代码,以帮助读者更好的理解并处理这个问题。 一、问题解…

    编程 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

发表回复

登录后才能评论