一些js数组方法
indexOf()
indexOf()
方法是 JavaScript 中用于查找数组中指定元素的位置的方法。它返回第一个匹配的元素的索引值,如果数组中不存在该元素,则返回 -1。
indexOf()
方法有一个必需的参数:要查找的元素值。另外还有一个可选的参数:要查找的起始位置(从该位置开始向后查找),默认值为 0。
下面是 indexOf()
方法的语法:
array.indexOf(searchElement[, fromIndex])
其中:
array
:必需,要进行查找的数组。searchElement
:必需,要查找的元素。fromIndex
:可选,要查找的起始位置。如果省略,则默认从数组的第一个元素开始查找。
下面是 indexOf()
方法的使用示例:
const arr = [1, 2, 3, 4, 5];
console.log(arr.indexOf(3)); // 2
console.log(arr.indexOf(6)); // -1
console.log(arr.indexOf(1, 1)); // -1
在第一个示例中,indexOf()
方法查找数组中第一个值为 3 的元素,返回它的索引值 2。
在第二个示例中,indexOf()
方法查找数组中第一个值为 6 的元素,由于该元素不存在,返回 -1。
在第三个示例中,indexOf()
方法从索引值 1 开始查找数组中第一个值为 1 的元素,由于该元素不存在于从索引值 1 开始的子数组中,返回 -1。
需要注意的是,indexOf()
方法是区分数据类型的,如果要查找的元素和数组中的元素类型不同,则不会进行自动类型转换,而是直接返回 -1。
reduce()
1、语法
arr.reduce(callback,[initialValue])
reduce 为数组中的每一个元素依次执行回调函数,不包括数组中被删除或从未被赋值的元素,接受四个参数:初始值(或者上一次回调函数的返回值),当前元素值,当前索引,调用 reduce 的数组。
callback (执行数组中每个值的函数,包含四个参数)
1、previousValue (上一次调用回调返回的值,或者是提供的初始值(initialValue))
2、currentValue (数组中当前被处理的元素)
3、index (当前元素在数组中的索引)
4、array (调用 reduce 的数组)
initialValue (作为第一次调用 callback 的第一个参数。)
如果省略了初始值initialValue,那么累加器函数将以数组的第一个元素作为初始值,并从数组的第二个元素开始迭代。
2、实例解析 initialValue 参数
先看第一个例子:
var arr = [1, 2, 3, 4];
var sum = arr.reduce(function(prev, cur, index, arr) {
console.log(prev, cur, index);
return prev + cur;
})
console.log(arr, sum);
打印结果: 1 2 1 3 3 2 6 4 3 [1, 2, 3, 4] 10
这里可以看出,上面的例子index是从1开始的,第一次的prev的值是数组的第一个值。数组长度是4,但是reduce函数循环3次。
再看第二个例子:
var arr = [1, 2, 3, 4];
var sum = arr.reduce(function(prev, cur, index, arr) {
console.log(prev, cur, index);
return prev + cur;
},0) //注意这里设置了初始值
console.log(arr, sum);
打印结果: 0 1 0 1 2 1 3 3 2 6 4 3 [1, 2, 3, 4] 10
这个例子index是从0开始的,第一次的prev的值是我们设置的初始值0,数组长度是4,reduce函数循环4次。
结论:如果没有提供initialValue,reduce 会从索引1的地方开始执行 callback 方法,跳过第一个索引。如果提供initialValue,从索引0开始。
注意:如果这个数组为空,运用reduce是什么情况?
var arr = [];
var sum = arr.reduce(function(prev, cur, index, arr) {
console.log(prev, cur, index);
return prev + cur;
})
//报错,"TypeError: Reduce of empty array with no initial value"
但是要是我们设置了初始值就不会报错,如下
var arr = [];
var sum = arr.reduce(function(prev, cur, index, arr) {
console.log(prev, cur, index);
return prev + cur;
},0)
console.log(arr, sum); // [] 0
所以一般来说我们提供初始值通常更安全
3、reduce的简单用法
当然最简单的就是我们常用的数组求和,求乘积了。
var arr = [1, 2, 3, 4];
var sum = arr.reduce((x,y)=>x+y)
var mul = arr.reduce((x,y)=>x*y)
console.log( sum ); //求和,10
console.log( mul ); //求乘积,24
4、reduce的高级用法
(1)计算数组中每个元素出现的次数
let names = ['Alice', 'Bob', 'Tiff', 'Bruce', 'Alice'];
let nameNum = names.reduce((pre,cur)=>{
if(cur in pre){
pre[cur]++
}else{
pre[cur] = 1
}
return pre
},{})
console.log(nameNum); //{Alice: 2, Bob: 1, Tiff: 1, Bruce: 1}
(2)数组去重
let arr = [1,2,3,4,4,1]
let newArr = arr.reduce((pre,cur)=>{
if(!pre.includes(cur)){
return pre.concat(cur)
}else{
return pre
}
},[])
console.log(newArr);// [1, 2, 3, 4]
(3)将二维数组转化为一维
let arr = [[0, 1], [2, 3], [4, 5]]
let newArr = arr.reduce((pre,cur)=>{
return pre.concat(cur)
},[])
console.log(newArr); // [0, 1, 2, 3, 4, 5]
(3)将多维数组转化为一维
let arr = [[0, 1], [2, 3], [4,[5,6,7]]]
const newArr = function(arr){
return arr.reduce((pre,cur)=>pre.concat(Array.isArray(cur)?newArr(cur):cur),[])
}
console.log(newArr(arr)); //[0, 1, 2, 3, 4, 5, 6, 7]
(4)对象里的属性求和
var result = [
{
subject: 'math',
score: 10
},
{
subject: 'chinese',
score: 20
},
{
subject: 'english',
score: 30
}
];
var sum = result.reduce(function(prev, cur) {
return cur.score + prev;
}, 0);
console.log(sum) //60
filter()
filter()
是JS数组的一个高阶函数,用于过滤数组中的元素,只保留符合条件的元素,并返回一个新数组。filter()
方法接受一个回调函数作为参数,这个回调函数会接受三个参数:当前元素,当前索引和数组本身。
回调函数需要返回一个布尔值,指示当前元素是否保留在新数组中。
语法如下:
array.filter(callback(element[, index[, array]])[, thisArg])
其中:
-
callback:必选参数,回调函数,用于测试数组中的每个元素,接受三个参数:
- element:必选参数,当前元素。
- index:可选参数,当前元素的索引。
- array:可选参数,数组本身。
-
thisArg:可选参数,回调函数中的this对象。
filter()
方法会遍历数组中的每个元素,并调用回调函数进行测试。如果回调函数返回true,则当前元素保留在新数组中,否则被过滤掉。最后,filter()
方法返回一个新数组,包含所有保留下来的元素。
下面是一个使用filter()
方法过滤偶数的例子:
const arr = [1, 2, 3, 4, 5, 6];
const newArr = arr.filter(function(element) {
return element % 2 === 0;
});
console.log(newArr); // [2, 4, 6]
在这个例子中,filter()
方法遍历数组中的每个元素,将每个元素传递给回调函数进行测试。如果元素是偶数,回调函数返回true,当前元素被保留在新数组中。最终,newArr
数组只包含偶数元素。
fill()
fill()
方法是ES6中新增的数组方法,可以用来填充一个数组中指定区间的元素,它会将数组中的指定区间全部替换成一个指定的值。
fill()
方法有两个参数,第一个参数是要填充的值,第二个参数是要替换的开始位置和结束位置,默认填充整个数组。
下面是 fill()
方法的语法:
javascriptCopy code
arr.fill(value, start, end);
其中:
value
:必需,用来填充数组元素的值。start
:可选,填充开始位置的索引(包括该位置)。end
:可选,填充结束位置的索引(不包括该位置)。
当省略第二个和第三个参数时,fill()
方法会将整个数组中的元素全部替换成指定的值。
下面是 fill()
方法的使用示例:
// 将一个空数组用 0 填充 3 次
const arr1 = new Array(3).fill(0);
console.log(arr1); // [0, 0, 0]
// 将数组中的指定区间替换成指定的值
const arr2 = [1, 2, 3, 4, 5];
arr2.fill(0, 1, 4); // 从索引为 1 的位置开始,到索引为 4 的位置结束(不包括索引为 4 的位置)
console.log(arr2); // [1, 0, 0, 0, 5]
在第一个示例中,fill()
方法将一个长度为 3 的空数组填充为 [0, 0, 0]
。
在第二个示例中,fill()
方法将数组中从索引为 1 的位置开始,到索引为 4 的位置结束(不包括索引为 4 的位置)的元素全部替换成了 0,结果为 [1, 0, 0, 0, 5]
。
some()
和every()
方法
some()
方法和every()
方法:这两个方法都是用于判断数组中的元素是否满足指定的条件。
some()
方法用于判断数组中是否存在满足条件的元素,只要有一个元素满足条件,就返回true,否则返回false;
every()
方法用于判断数组中的所有元素是否都满足指定的条件,只有所有元素都满足条件,才返回true,否则返回false。
这两个方法都接受一个回调函数作为参数,回调函数接受三个参数,分别为当前值、当前索引和数组本身。
下面是一个简单的使用some()
方法和every()
方法的例子:
javascriptCopy code
const arr = [1, 2, 3, 4, 5];
const isSomeEven = arr.some(function(element) {
return element % 2 === 0;
});
const isEveryEven = arr.every(function(element) {
return element % 2 === 0;
});
console.log(isSomeEven); // true,存在偶数
console.log(isEveryEven); // false,不是所有元素
Set对象
ES6中的Set是一种新的数据结构,它是一组不重复且无序的值的集合。可以把它看作是一个数组,但是它的成员不能重复,并且没有顺序之分。
Set对象的特点:
- Set对象中的元素都是唯一的,不会有重复的值。
- Set对象中的元素是无序的,即添加元素的顺序和遍历元素的顺序不一定一致。
Set对象有以下的方法:
add(value)
:向Set对象添加一个新元素。delete(value)
:删除Set对象中的指定元素。has(value)
:判断Set对象是否包含指定元素,返回一个布尔值。clear()
:清空Set对象中的所有元素。size
:返回Set对象中元素的个数。
下面是一个简单的使用Set对象的例子:
javascriptCopy code
const set = new Set();
set.add(1);
set.add(2);
set.add(3);
set.add(1); // 添加重复的元素,但是Set对象只会保留一个
console.log(set); // Set { 1, 2, 3 }
console.log(set.has(1)); // true
console.log(set.has(4)); // false
console.log(set.size); // 3
set.delete(2);
console.log(set); // Set { 1, 3 }
set.clear();
console.log(set); // Set {}
在这个例子中,首先创建了一个空的Set对象,然后使用add()
方法向Set对象添加四个元素。由于Set对象中的元素不能重复,所以重复添加的元素只会保留一个。使用has()
方法判断Set对象中是否包含指定元素。使用delete()
方法删除指定元素。使用size
属性获取Set对象中元素的个数。最后,使用clear()
方法清空Set对象中的所有元素。
需要注意的是,Set对象中的元素是唯一的,它使用“Same-value-zero equality”算法来比较元素是否相等。对于NaN这种特殊值,它在Set对象中只能出现一次,因为NaN与自身不相等,但在Set对象中被认为是相等的。
转载自:https://juejin.cn/post/7222294792893497381