当前位置:首页 > JavaScript

js filter实现

2026-03-14 16:01:23JavaScript

使用 JavaScript 的 filter 方法

JavaScript 的 filter 方法是数组原型上的一个方法,用于创建一个新数组,其中包含通过指定函数测试的所有元素。filter 不会改变原数组,而是返回一个新数组。

语法如下:

js filter实现

const newArray = array.filter(callback(element[, index[, array]])[, thisArg])
  • callback:测试数组每个元素的函数,返回 true 表示保留该元素,false 则不保留。
  • element:当前处理的元素。
  • index(可选):当前元素的索引。
  • array(可选):调用 filter 的数组本身。
  • thisArg(可选):执行 callback 时使用的 this 值。

基本用法示例

过滤数组中的偶数:

const numbers = [1, 2, 3, 4, 5, 6];
const evenNumbers = numbers.filter(num => num % 2 === 0);
console.log(evenNumbers); // [2, 4, 6]

过滤对象数组中符合条件的对象:

js filter实现

const users = [
  { name: 'Alice', age: 25 },
  { name: 'Bob', age: 30 },
  { name: 'Charlie', age: 20 }
];
const adults = users.filter(user => user.age >= 25);
console.log(adults); // [{ name: 'Alice', age: 25 }, { name: 'Bob', age: 30 }]

结合索引使用

filter 的回调函数可以接收索引参数,用于基于索引的过滤:

const fruits = ['apple', 'banana', 'orange', 'grape'];
const filteredFruits = fruits.filter((fruit, index) => index % 2 === 0);
console.log(filteredFruits); // ['apple', 'orange']

链式调用

filter 可以与其他数组方法(如 mapreduce)链式调用:

const numbers = [1, 2, 3, 4, 5];
const doubledEvens = numbers
  .filter(num => num % 2 === 0)
  .map(num => num * 2);
console.log(doubledEvens); // [4, 8]

注意事项

  • filter 不会修改原数组,而是返回一个新数组。
  • 如果没有任何元素通过测试,filter 返回一个空数组。
  • filter 会跳过稀疏数组中不存在的元素(如 [1, , 3] 中的空位)。

标签: jsfilter
分享给朋友:

相关文章

js实现

js实现

JavaScript 实现方法 JavaScript 是一种广泛使用的编程语言,适用于网页开发、服务器端编程以及移动应用开发。以下是几种常见的 JavaScript 实现方法: 网页交互功能 使用…

js实现复制

js实现复制

使用document.execCommand方法 在较旧的浏览器中,可以使用document.execCommand('copy')实现复制功能。创建一个临时的textarea或input元素,将需要…

js实现图片轮播

js实现图片轮播

实现基础图片轮播 使用HTML、CSS和JavaScript创建一个简单的图片轮播。HTML部分定义轮播容器和图片,CSS设置样式和动画效果,JavaScript处理轮播逻辑。 <div cl…

js 实现vue

js 实现vue

Vue.js 的基本实现 在 JavaScript 中实现 Vue.js 的核心功能,可以通过数据绑定、响应式系统和虚拟 DOM 来实现。以下是实现 Vue.js 核心功能的简化版本。 数据响应式系…

js实现预览

js实现预览

文件上传预览实现 使用JavaScript实现文件上传预览功能,可以通过FileReader对象读取文件内容并显示预览。以下代码支持图片、文本和PDF文件的预览: // HTML部分需要包含inpu…

js实现点击显示和隐藏

js实现点击显示和隐藏

实现点击显示和隐藏的JavaScript方法 使用classList.toggle切换类名 通过添加/移除CSS类控制元素的显示与隐藏,需提前在CSS中定义隐藏样式(如display: none)。…