目录
引言
什么是过滤器?
过滤器的用法
定义
语法
参数说明
filter的实例
filter是深拷贝还是浅拷贝?
注意
浏览器支持
小结
写在最后
引言
大家好,我是黛玉葬花,过滤器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)
输出结果:
如输出结果所示,上面的代码打印出了对应次数的obj对象。
当我们去掉obj的时候,会打印window,如下图所示:
那为什么这个时候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
输出结果:
filter()的大致意思我们搞懂了,接下来看一些操作赋值的实践案例。
filter的实例
获取nums数组大于5的值
let nums = [1,2,3,4,5,6,7,8,9,10]
nums.filter(function(item){
return item > 5
})
输出结果:
获取nums数组中的偶数
let nums = [1,2,3,4,5,6,7,8,9,10]
nums.filter(function(item){
return item%2 == 0
})
输出结果:
筛选不包含 '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] 原数组值不变
浏览器支持
表格中的数字代表支持该方法的第一个浏览器版本号
小结
- 过滤器的主要作用是过滤,可以轻松得到我们想要的数据;
- filter()有两个参数,function()和thisValue;
- thisValue在传入对象的时候,this打印的是传入的对象;没传对象的时候,非严格模式下打印的是 window,严格模式下打印的是undefined;
- 在一个多维数组的情况下filter()是一个浅拷贝,在一个数据类型全部是基本数据类型的话filter()是一个深拷贝;
- filter()不会对空数组进行检测;
- filter()不会改变原始数组;