一些js数组方法

lxf2023-05-05 06:09:01

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 (当前元素在数组中的索引)
     4array (调用 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对象中被认为是相等的。