概述 :数组基本操作可以归纳为增,删,改,查
这些方法需要注意的是哪些方法会对原数组产生影响,哪些不会

1、增:

push()

push()方法接收任意数量的参数,并将它们添加到数组末尾,返回的是数组的最新长度

  1. let arr = [1,2];
  2. let arrPushLength = arr.push(1,2)
  3. console.log(arrPushLength) //4
  4. console.log(arr) //[ 1, 2, 1, 2 ]

unshift()

unshift()在数组开头添加任意多个值,然后返回新的数组长度

  1. let arr = [1,2];
  2. let arrUnshiftLength = arr.unshift(2,3)
  3. console.log(arrUnshiftLength)//4
  4. console.log(arr) //[ 2, 3, 1, 2 ]

splice()

splice()方法传入三个参数,分别是,开始下标,删除元素个数,插入的元素.
1.传入一个参数,会返回从这个下标开始的后面的元素
2.传入2个参数,如果第二个参数为0,则返回空数组,如果不为0,则把删除的元素以数组的形式返回
3.如果是三个参数,第一个参数为开始下标,第二个参数为删除元素的个数,第三个参数是添加的元素,如果第二个参数为0则返回空数组,不为0就会返回被删除的元素

  1. let arr = [2,5,8];
  2. let arrSpliceNull = arr.splice(1,0,6,5)
  3. console.log(arrSpliceNull)//[]
  4. console.log(arr)//[ 2, 6, 5, 5, 8 ]
  1. let arr = [2,5,8];
  2. let arrSpliceNull = arr.splice(1,1,6,5)
  3. console.log(arrSpliceNull)//[5]
  4. console.log(arr)//[ 2, 6, 5, 8 ]

concat()

首先会创建首先会创建一个当前数组的副本,然后再把它的参数添加到副本末尾,最后返回这个新构建的数组,不会影响原始数组

  1. let colors = ["red", "green", "blue"];
  2. let colors2 = colors.concat("yellow", ["black", "brown"]);
  3. console.log(colors); // ["red", "green","blue"]
  4. console.log(colors2); // ["red", "green", "blue", "yellow", "black", "brown"]

总结

push,unshift,splice都会改变原数组

而concat不会影响原数组

2、删

pop()

pop()方法用于删除数组的最后一项,同时减少数组的length值,返回被删除的项

  1. let arr = [1,2,3]
  2. let arrPop = arr.pop()
  3. console.log(arrPop) //3
  4. console.log(arr) //[1,2]

shift()

shift()方法用于删除数组的第一项,同时减少数组的length 值,返回被删除的项

  1. let arr = [1,2,3]
  2. let arrShift = arr.pop()
  3. console.log(arrShift) //1
  4. console.log(arr) //[2,3]

splice()

上边有

slice()

slice() 用于创建一个包含原有数组中一个或多个元素的新数组,不会影响原始数组

1.如果一个参数,那么就会从这个下标开始一直到结束

  1. let arr = [1,2,3,4,5]
  2. let arrSlice = arr.slice(1)
  3. console.log(arrSlice)//[2,3,4,5]
  4. console.log(arr)//[1,2,3,4,5]

2.如果两个参数,那么就从第一个参数下标开始,一直到第二个下标(不包括)结束

  1. let arr = [1,2,3,4,5]
  2. let arrSlice = arr.slice(1,3)
  3. console.log(arrSlice)//[2,3]
  4. console.log(arr)//[1,2,3,4,5]

3、改

splice()

4、查

indexOf()

返回要查找的元素在数组中的位置,如果没找到则返回-1

includes()

返回要查找的元素在数组中的位置,找到返回true,否则false

find()

返回第一个匹配的元素

  1. const people = [
  2. {
  3. name: "Matt",
  4. age: 27
  5. },
  6. {
  7. name: "Nicholas",
  8. age: 29
  9. }
  10. ];
  11. people.find((element, index, array) => element.age < 28) // // {name: "Matt", age: 27}

排序方法

反转数组reverse()

  1. let values = [2,5,1,56,85,12,35];
  2. values.reverse();
  3. console.log(values); // [35, 12, 85, 56,1,5,2]

sort()方法接受一个比较函数,用于判断哪个值应该排在前面

  1. function compare(value1, value2) {
  2. if (value1 > value2) {
  3. return -1;
  4. } else if (value1 > value2) {
  5. return 1;
  6. } else {
  7. return 0;
  8. }
  9. }
  10. let values = [0, 1, 5, 10, 15];
  11. values.sort(compare);
  12. console.log(values); // [ 15, 10, 5, 1, 0 ]

三、转换方法

join()

join() 方法接收一个参数,即字符串分隔符,返回包含所有项的字符串

以字符串的方式拼接

  1. let colors = ["red", "green", "blue"];
  2. console.log(colors.join(",")); // red,green,blue
  3. console.log(colors.join("||")); // red||green||blue

迭代方法

在数组尾部添加一个元素push

  1. 在数组头部添加一个元素unshift
  2. 在数组尾部删除一个元素pop()
  3. 在数组头部删除一个元素shift()
  4. 合并数组concat() var a = arr1.concat(arr2);
  5. 操作子数组的方法splice()删除,替换,添加,更新
  6. splice(获取下标值,删除个数,替换的元素);
  7. 数组的截取slice() 数组.slice(); [)

数组的迭代:

迭代器:

forEach, map, every,some,filter,reduce;

forEach

  1. //格式//forEach(function(value,index,arr){})
  2. //value:数值
  3. //index:下标
  4. //arr:原数值
  5. var arr2 = [1,2,3,4,5];
  6. arr2.forEach(function(value,index,arr2){
  7. console.log(value+index+arr2);
  8. })//

映射map()

  1. var arr2 = [1,2,3,4,5];
  2. var result = arr2.map(function(value,index,arr2){
  3. return value * 2;
  4. })
  5. console.log(retult);//

every

  1. //every要求自定义条件都符合的情况下才返回true,否则有一个不合格就会返回false
  2. var arr2 = [1,2,3,4,5];
  3. var result = arr2.every(function(intm){
  4. return intm % 2 == 0;
  5. })
  6. console.log(retult);//false

some

  1. //some要求自定义条件只要有一个符合的情况下返回true,否则返回false
  2. var arr2 = [1,2,3,4,5];
  3. var result = arr2.some(function(intm){
  4. return intm % 2 == 0;
  5. })
  6. console.log(retult);//true

filter(过滤)

把符合条件的元素留下,返回一个新数组,不符合条件的元素过滤掉

  1. var arr2 = [1,2,3,4,5];
  2. var result = arr2.filter(function(intm){
  3. return intm % 2 == 0;
  4. })
  5. console.log(retult);//2

reduce()

累加器

  1. var arr2 = [1,2,3,4,5];
  2. reduce(function(initValue,currentValue,index,arr2){
  3. //initValue:初始值
  4. // ,currentValue:当前值
  5. // ,index:下标值,
  6. // arr2:原数组
  7. })
  8. var result = arr2.renuce(function(a,b){
  9. return a + b;
  10. },可以设定初始值)
  11. console.log(retult);//