目录

引言

什么是过滤器?

过滤器的用法

定义

语法

参数说明

filter的实例

filter是深拷贝还是浅拷贝?

注意

浏览器支持

小结

写在最后


                 

java filter过滤器获取response中的对象 js filter过滤器用法_javascript

引言

大家好,我是黛玉葬花,过滤器filter在前端代码开发中,用到的地方很多,今天我们就来讲讲JavaScript中过滤器的详细用法!


什么是过滤器?

filter过滤器:用于把Array的某些元素过滤掉,返回剩下的元素。生活中用到的筛子就是过滤器,细孔的筛子可以用来过滤出粉质细腻的面粉,粗一点的筛子可以用来过滤出个头饱满的黄豆,把一些未发育完全的瞎豆子筛出去;净水器可以过滤水中杂质,得到干净的水。我们的代码中也可以用过滤器,得到我们想要的结果!


过滤器的用法

定义

filter()方法创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素。

语法

array.filter(function(currentValue,index,arr), thisValue)

参数说明

filter()方法有两个参数,第一个是function(),第二个是thisValue。

  • function():必须。数组中的每个元素都会执行这个函数。return后面判断结果,取布尔值,返回值是true则该元素被保留,是false则丢弃该元素。入参如下:
  • currentValue:必须。当前元素的值;
  • index:可选。当前元素的索引值;
  • arr:可选。当前元素属于的数组对象;
  • thisValue:可选。对象作为该执行回调时使用,传递给函数,用作 "this" 的值。如果省略了 thisValue ,"this" 的值为 "undefined";

打印一下this看看:

let arr=[1,2,3,4,5,6,7,8];
let obj={
    name:'123',
    age:12,
    sum:100
}
let arr1= arr.filter(function(value,index,arr){
    console.log(this)
    return arr[index]
},obj)

输出结果:

java filter过滤器获取response中的对象 js filter过滤器用法_开发语言_02

如输出结果所示,上面的代码打印出了对应次数的obj对象。

当我们去掉obj的时候,会打印window,如下图所示:

java filter过滤器获取response中的对象 js filter过滤器用法_javascript_03

那为什么这个时候this打印出来的是window而不是上面所说的undefined呢?我们来看下,这是因为在非严格模式下,会打印window,在严格模式下,才会打印undefined。

"use strict"; // 使用严格模式
let arr=[1,2,3,4,5,6,7,8];
let obj={
    name:'123',
    age:12,
    sum:100
}
let arr1= arr.filter(function(value,index,arr){
    console.log(this)
    return arr[index]
})

// undefined

输出结果:

java filter过滤器获取response中的对象 js filter过滤器用法_开发语言_04

filter()的大致意思我们搞懂了,接下来看一些操作赋值的实践案例。


filter的实例

获取nums数组大于5的值

let nums = [1,2,3,4,5,6,7,8,9,10]
nums.filter(function(item){
    return item > 5
})

输出结果:

java filter过滤器获取response中的对象 js filter过滤器用法_开发语言_05

获取nums数组中的偶数

let nums = [1,2,3,4,5,6,7,8,9,10]
nums.filter(function(item){
    return item%2 == 0
})

输出结果:

java filter过滤器获取response中的对象 js filter过滤器用法_javascript_06

筛选不包含 'b' 的字符串

let arr = ['aa','cb','cc', 'bd','rf']
let newArr = arr.filter(item => item.indexOf('b')<0)  
// ["aa", "cc", "rf"]

filter是深拷贝还是浅拷贝?

举个🌰:

// 数组对象
let arr=[1,2,3,4,5,6,7,8,[1,1,1]];
// 对象
let obj={
    name: '黛玉',
    age: 14,
    sum: 100
}
// Number
let test = 8
let test1 = test
// filter方法
let arr1= arr.filter(function(value,index,arr){
    obj.sum+=value
    test1 = test1 + value
    return value
},obj)
arr1[arr.length-1].push(2)

console.log(arr) // [1, 2, 3, 4, 5, 6, 7, 8, [1, 1, 1, 2]]
console.log(obj) // {name: '123', age: 12, sum: '1361,1,1'}
console.log(test) // 8
console.log(test1) // 441,1,1

这里我们可以看到,在一个数据类型全部是基本数据类型的话是一个深拷贝。例如test和test1;

在多维数组中是浅拷贝,当filter()方法结束后,改变arr1数组的值,打印arr数组,arr数组的值跟着变了,所以arr数组和arr1数组是指向同一个地址的,验证filter()方法在数组中是浅拷贝。


注意

注意:filter() 不会对空数组进行检测。

注意:filter() 不会改变原始数组。

let arr=[1,2,3,4,5,6,7,8];
let arr1= arr.filter(function(value,index,arr){
    arr[index]=value++
    return arr[index] > 4
})
console.log(arr1) // [5, 6, 7, 8]
console.log(arr) // [1, 2, 3, 4, 5, 6, 7, 8] 原数组值不变

浏览器支持

java filter过滤器获取response中的对象 js filter过滤器用法_数组_07

表格中的数字代表支持该方法的第一个浏览器版本号


小结

  • 过滤器的主要作用是过滤,可以轻松得到我们想要的数据;
  • filter()有两个参数,function()和thisValue;
  • thisValue在传入对象的时候,this打印的是传入的对象;没传对象的时候,非严格模式下打印的是 window,严格模式下打印的是undefined;
  • 在一个多维数组的情况下filter()是一个浅拷贝,在一个数据类型全部是基本数据类型的话filter()是一个深拷贝;
  • filter()不会对空数组进行检测;
  • filter()不会改变原始数组;