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/zh-hant/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

發表回復

登錄後才能評論