概述 :数组基本操作可以归纳为增,删,改,查
这些方法需要注意的是哪些方法会对原数组产生影响,哪些不会
1、增:
push()
push()方法接收任意数量的参数,并将它们添加到数组末尾,返回的是数组的最新长度
let arr = [1,2];
let arrPushLength = arr.push(1,2)
console.log(arrPushLength) //4
console.log(arr) //[ 1, 2, 1, 2 ]
unshift()
unshift()在数组开头添加任意多个值,然后返回新的数组长度
let arr = [1,2];
let arrUnshiftLength = arr.unshift(2,3)
console.log(arrUnshiftLength)//4
console.log(arr) //[ 2, 3, 1, 2 ]
splice()
splice()方法传入三个参数,分别是,开始下标,删除元素个数,插入的元素.
1.传入一个参数,会返回从这个下标开始的后面的元素
2.传入2个参数,如果第二个参数为0,则返回空数组,如果不为0,则把删除的元素以数组的形式返回
3.如果是三个参数,第一个参数为开始下标,第二个参数为删除元素的个数,第三个参数是添加的元素,如果第二个参数为0则返回空数组,不为0就会返回被删除的元素
let arr = [2,5,8];
let arrSpliceNull = arr.splice(1,0,6,5)
console.log(arrSpliceNull)//[]
console.log(arr)//[ 2, 6, 5, 5, 8 ]
let arr = [2,5,8];
let arrSpliceNull = arr.splice(1,1,6,5)
console.log(arrSpliceNull)//[5]
console.log(arr)//[ 2, 6, 5, 8 ]
concat()
首先会创建首先会创建一个当前数组的副本,然后再把它的参数添加到副本末尾,最后返回这个新构建的数组,不会影响原始数组
let colors = ["red", "green", "blue"];
let colors2 = colors.concat("yellow", ["black", "brown"]);
console.log(colors); // ["red", "green","blue"]
console.log(colors2); // ["red", "green", "blue", "yellow", "black", "brown"]
总结
push,unshift,splice都会改变原数组
而concat不会影响原数组
2、删
pop()
pop()方法用于删除数组的最后一项,同时减少数组的length值,返回被删除的项
let arr = [1,2,3]
let arrPop = arr.pop()
console.log(arrPop) //3
console.log(arr) //[1,2]
shift()
shift()
方法用于删除数组的第一项,同时减少数组的length
值,返回被删除的项
let arr = [1,2,3]
let arrShift = arr.pop()
console.log(arrShift) //1
console.log(arr) //[2,3]
splice()
上边有
slice()
slice() 用于创建一个包含原有数组中一个或多个元素的新数组,不会影响原始数组
1.如果一个参数,那么就会从这个下标开始一直到结束
let arr = [1,2,3,4,5]
let arrSlice = arr.slice(1)
console.log(arrSlice)//[2,3,4,5]
console.log(arr)//[1,2,3,4,5]
2.如果两个参数,那么就从第一个参数下标开始,一直到第二个下标(不包括)结束
let arr = [1,2,3,4,5]
let arrSlice = arr.slice(1,3)
console.log(arrSlice)//[2,3]
console.log(arr)//[1,2,3,4,5]
3、改
splice()
4、查
indexOf()
返回要查找的元素在数组中的位置,如果没找到则返回-1
includes()
返回要查找的元素在数组中的位置,找到返回true
,否则false
find()
返回第一个匹配的元素
const people = [
{
name: "Matt",
age: 27
},
{
name: "Nicholas",
age: 29
}
];
people.find((element, index, array) => element.age < 28) // // {name: "Matt", age: 27}
排序方法
反转数组reverse()
let values = [2,5,1,56,85,12,35];
values.reverse();
console.log(values); // [35, 12, 85, 56,1,5,2]
sort()方法接受一个比较函数,用于判断哪个值应该排在前面
function compare(value1, value2) {
if (value1 > value2) {
return -1;
} else if (value1 > value2) {
return 1;
} else {
return 0;
}
}
let values = [0, 1, 5, 10, 15];
values.sort(compare);
console.log(values); // [ 15, 10, 5, 1, 0 ]
三、转换方法
join()
join() 方法接收一个参数,即字符串分隔符,返回包含所有项的字符串
以字符串的方式拼接
let colors = ["red", "green", "blue"];
console.log(colors.join(",")); // red,green,blue
console.log(colors.join("||")); // red||green||blue
迭代方法
在数组尾部添加一个元素push
在数组头部添加一个元素unshift
在数组尾部删除一个元素pop()
在数组头部删除一个元素shift()
合并数组concat() var a = arr1.concat(arr2);
操作子数组的方法splice()删除,替换,添加,更新
splice(获取下标值,删除个数,替换的元素);
数组的截取slice() 数组.slice(); [)
数组的迭代:
迭代器:
forEach, map, every,some,filter,reduce;
forEach
//格式//forEach(function(value,index,arr){})
//value:数值
//index:下标
//arr:原数值
var arr2 = [1,2,3,4,5];
arr2.forEach(function(value,index,arr2){
console.log(value+index+arr2);
})//
映射map()
var arr2 = [1,2,3,4,5];
var result = arr2.map(function(value,index,arr2){
return value * 2;
})
console.log(retult);//
every
//every要求自定义条件都符合的情况下才返回true,否则有一个不合格就会返回false
var arr2 = [1,2,3,4,5];
var result = arr2.every(function(intm){
return intm % 2 == 0;
})
console.log(retult);//false
some
//some要求自定义条件只要有一个符合的情况下返回true,否则返回false
var arr2 = [1,2,3,4,5];
var result = arr2.some(function(intm){
return intm % 2 == 0;
})
console.log(retult);//true
filter(过滤)
把符合条件的元素留下,返回一个新数组,不符合条件的元素过滤掉
var arr2 = [1,2,3,4,5];
var result = arr2.filter(function(intm){
return intm % 2 == 0;
})
console.log(retult);//2
reduce()
累加器
var arr2 = [1,2,3,4,5];
reduce(function(initValue,currentValue,index,arr2){
//initValue:初始值
// ,currentValue:当前值
// ,index:下标值,
// arr2:原数组
})
var result = arr2.renuce(function(a,b){
return a + b;
},可以设定初始值)
console.log(retult);//