js数组的常用方法
干货满满
var arr = new Array(1, 2, 3, 4, 5, 6, 7, 8, 9);
// ################# 增加
var length = arr.push(10); // push()返回数组中元素的个数,向数组尾部中增加元素,有多少加多少,原数组发生改变。
arr.unshift(0); // 返回数组中元素的个数向数组的头部增加元素,括号中有多少就加多少,原数组发生改变
// ################ 删
arr.pop(); // pop()从数组的尾部删除一个元素,返回这个删除的元素,不接收参数
arr.shift(); // 从数组的头部删除一个元素,返回这个删除的元素,不接收参数
// ################ 综合方法 (此方法原数组不变)
arr.slice(4); // 从下标为4的开始截取,直至数组结束
arr.slice(0, 2); // 从下标0开始截取,到下标2结束,不包含下标2的数,
//
// ################ 综合方法 (改变原数组) 获取新的数组 (可以将一个数组切成两个数组)
arr.splice(4); // 一个参数,从下标4对应的位置开始,直到数组结束
arr.splice(0, 1); // 两个参数从 第一个参数 下标为0开始,第二个参数截取长度 1
// ################ 综合方法 排序 翻转
arr.reverse(); // 数组翻转,该方法会改变原来的数组,而不会创建新的数组 (改变原数组)
arr.sort(); // 无参数默认从小到大排序,判断方式:按位判断 (改变原数组)
arr.sort(function (a, b) {
return b - a; // 从大到小排序
return a - b; //从小到大排列
});
var arr1 = [11, 12];
var arr3 = arr1.concat(arr, 33, 44); //将arr1,arr,33,44拼接为一个新的数组,用arr3接收
arr.join("-"); //将数组转化为为字符串,以括号内的拼接
数组的遍历方法
干货满满
var arr = new Array(1, 2, 3, 4, 5, 6, 7, 8, 9);
// 循环一 for
for(let i=0;i<10;i++){
//执行代码块
console.log(i)
break;
}
// break 中断循环
// 循环二 forEach
arr.forEach((item,index,array)=>{
//执行代码
})
// 数组中有几项,那么传递进去的匿名回调函数就需要执行几次;
// 遍历数组中的每一项,没有返回值,对原数组没有影响,不支持IE
// 循环三 map 映射(生成新的数组)
arr2 = arr.map(function(value,index,array){
// 执行代码
return value + 10
})
// map的回调函数中支持return返回值
// 循环四 forof
for (var value of arr) {
console.log(value);
}
//可以正确响应break、continue
// 循环五 filter 过滤 (生成新的数组)
var arr = [
{ id: 1, text: 'aa', done: true },
{ id: 2, text: 'bb', done: false }
]
arr.filter(function (item) {
if (item.done) {
return false; // 淘汰
} else {
return true; // 过关
}
});
var arr = [73,84,56, 22,100]
var newArr = arr.filter(item => item>80) //得到新数组 [84, 100]
console.log(newArr,arr)
// 循环六 every 如果该函数对每一项返回true,则返回true。
var arr = [ 1, 2, 3, 4, 5, 6 ];
console.log( arr.every( function( item, index, array ){
return item > 3;
}));
// false
//every()是对数组中的每一项运行给定函数,如果该函数对每一项返回true,则返回true。
// 循环七 some 如果该函数对任一项返回true,则返回true。
var arr = [ 1, 2, 3, 4, 5, 6 ];
console.log( arr.some( function( item, index, array ){
return item > 3;
}));
// true
// some()是对数组中每一项运行指定函数,如果该函数对任一项返回true,则返回true。
// 循环八 reduce 还有这个 reduceRight 反方向的。
[0, 1, 2, 3, 4].reduce(function(previousValue, currentValue, index, array){
return previousValue + currentValue;
});
//reduce接受一个函数,函数有四个参数,分别是:上一次的值,当前值,当前值的索引,数组
// 循环九 find
var stu = [
{
name: '张三',
gender: '男',
age: 20
},
{
name: '王小毛',
gender: '男',
age: 20
},
{
name: '李四',
gender: '男',
age: 20
}
]
function getStu(element){
return element.name == '李四'
}
stu.find((element)=> element.name == '李四')
// 返回结果为 {name: "李四", gender: "男", age: 20}
// find()方法返回数组中符合测试函数条件的第一个元素。否则返回undefined
// 循环一十 findIndex
// 对于数组中的每个元素,findIndex 方法都会调用一次回调函数(采用升序索引顺序),直到有元素返回 true。
// 只要有一个元素返回 true,findIndex 立即返回该返回 true 的元素的索引值
// 如果数组中没有任何元素返回 true,则 findIndex 返回 -1。
// findIndex 不会改变数组对象。
[1,2,3].findIndex(function(x) { x == 2; });
// Returns an index value of 1.
[1,2,3].findIndex(x => x == 4);
// Returns an index value of -1.
数组的查询方法
let arr = [1,2,3,4,5];
// 01- 是否存在 true | false
arr.includes(2); // true
// 02- 存在的位置 -1(不存在) | 具体下标
arr.indexOf(4) // 3
数组的数据处理方法
let arr = [[{ name: "dwp" }], [{ name: "dwp2" }], [{ name: "dwp3" }], [{ name: "dwp4" }]]
let art = arr.reduce((p, n) => {
console.log("p, n", p, n);
// return [p].concat([n]);
return [...p, ...n];
})
console.log(art);
注意
continue和break有点类似,区别在于continue只是终止本次循环,接着还执行后面的循环,break则完全终止循环。
最后
后续还会补充, 喜欢记得收藏。