//JS数组常用方法及其应用
/**
* 1.push(): 向数组尾部添加一个或多个元素,并返回添加新元素后的数组长度。注意,该方法会改变原数组。
* pop(): 删除数组的最后一个元素,并返回该元素。注意,该方法会改变原数组。
*/
let arr1 = ["a","b","c"];
console.log("arr1:" + arr1);
arr1.push("d");
console.log("arr1:" + arr1);
let t = arr1.pop();
console.log("arr1.pop():" + t);
console.log("arr1:" + arr1);
输出:
arr1:a,b,c
arr1:a,b,c,d
arr1.pop():d
arr1:a,b,c
/**
* 2.unshift():在数组的第一个位置添加元素,并返回添加新元素后的数组长度。注意,该方法会改变原数组。
* shift():删除数组的第一个元素,并返回该元素。注意,该方法会改变原数组。
*/
let arr1 = ["a","b","c"];
console.log("arr1:" + arr1);
arr1.unshift("d");
console.log("arr1:" + arr1);
arr1.shift();
console.log("arr1:" + arr1);
输出:
arr1:a,b,c
arr1:d,a,b,c
arr1:a,b,c
利用shift和pop方法可以分别正序逆序输出数组值,但是遍历之后原数组中的数据被清空了:
let elem;
while (elem = arr1.shift()) {
console.log(elem);
}
while (elem = arr1.pop()) {
console.log(elem);
}
/**
* 3.indexOf():返回指定元素在数组中出现的位置,如果没有出现则返回-1。indexOf方法还可以接受第二个参数,表示搜索的开始位置。
*/
let arr1 = ["a","b","c"];
console.log("arr1:" + arr1.indexOf("a"));
console.log("arr1:" + arr1.indexOf("d"));
console.log("arr1:" + arr1.indexOf("a",1));
输出:
arr1:0
arr1:-1
arr1:-1
利用indexof可以遍历数组,做数值的比较操作:
function topicsCompare( topics1, topics2, cb ){
let add = [];
let remove = [];
for (let key in topics1) {
let top1 = topics1[key];
// console.log("top1"+top1);
if( topics2.indexOf(top1) === (-1) ){
//输出topics1中存在,topics2中不存在的数据
console.log("---"+top1);
remove.push(top1);
}
}
for (let key in topics2) {
let top2 = topics2[key];
// console.log("top2"+top2);
if( topics1.indexOf(top2) === (-1) ){
//输出topics2中存在,topics1中不存在的数据
console.log("+++"+top2);
add.push(top2);
}
}
return cb(add,remove);
}
/**
* 4.join():以参数作为分隔符,将所有数组成员组成一个字符串返回。如果不提供参数,默认用逗号分隔。
*/
let arr1 = ["a","b","c"];
console.log("arr1:" + arr1);
console.log("arr1:" + arr1.join());
console.log("arr1:" + arr1.join(" "));
console.log("arr1:" + arr1.join("|"));
console.log("arr1:" + arr1.join("*"));
输出:
arr1:a,b,c
arr1:a,b,c
arr1:a b c
arr1:a|b|c
arr1:a*b*c
/**
* 5.concat():用于多个数组的合并。它将新数组的成员,添加到原数组的尾部,然后返回一个新数组,原数组不变。
*/
let arr1 = ["a","b","c"];
let arr2 = ["d","e"];
console.log("arr1:" + arr1);
console.log("arr1:" + arr1.concat(arr2));
输出:
arr1:a,b,c
arr1:a,b,c,d,e
/**
* 6.reverse():用于颠倒数组中元素的顺序,返回改变后的数组。注意,该方法将改变原数组。
*/
let arr1 = ["a","b","c"];
console.log("arr1:" + arr1);
console.log("arr1:" + arr1.reverse());
输出:
arr1:a,b,c
arr1:c,b,a
/**
* 7.slice():用于截取原数组的一部分,返回一个新数组,原数组不变。
* slice(start,end)它的第一个参数为起始位置(从0开始),第二个参数为终止位置(但该位置的元素本身不包括在内)。如果省略第二个参数,则一直返回到原数组的最后一个成员。
*/
let arr = ['a', 'b', 'c'];
console.log("arr1:" + arr.slice(0)); // ["a", "b", "c"]
console.log("arr1:" + arr.slice(1)); // ["b", "c"]
console.log("arr1:" + arr.slice(1, 2)); // ["b"]
console.log("arr1:" + arr.slice(2, 6)); // ["c"]
console.log("arr1:" + arr.slice()); // ["a", "b", "c"] 无参数返回原数组
console.log("arr1:" + arr.slice(-2)); // ["b", "c"] 参数是负数,则表示倒数计算的位置
console.log("arr1:" + arr.slice(-2, -1)); // ["b"]
输出:
arr1:a,b,c
arr1:b,c
arr1:b
arr1:c
arr1:a,b,c
arr1:b,c
arr1:b
/**
* 8.splice():删除原数组的一部分成员,并可以在被删除的位置添加入新的数组成员,返回值是被删除的元素。注意,该方法会改变原数组。
* splice(start,delNum,addElement1,addElement2,...)第一个参数是删除的起始位置,第二个参数是被删除的元素个数。如果后面还有更多的参数,则表示这些就是要被插入数组的新元素。
*/
let arr1 = ["a","b","c","d","e","f"];
let arr2 = ["1","2","3"];
console.log("arr1:" + arr1);
console.log("arr1:" + arr1.splice(4, 2));
console.log("arr1:" + arr1);
console.log("arr1:" + arr1.splice(4, 2, arr2));
console.log("arr1:"+ arr1);
console.log("arr1:" + arr1.splice(-4, 2));//起始位置如果是负数,就表示从倒数位置开始删除
console.log("arr1:"+ arr1);
console.log("arr1:" + arr1.splice(2, 0, "c", "d", "e", "f"));//如果只插入元素,第二个参数可以设为0,此处表示从第二个位置后面开始插入
console.log("arr1:"+ arr1);
console.log("arr1:" + arr1.splice(4));//如果只有第一个参数,等同于将原数组在指定位置拆分成两个数组
console.log("arr1:"+ arr1);//此处表示从第4个位置开始
输出:
arr1:a,b,c,d,e,f
arr1:e,f
arr1:a,b,c,d
arr1:
arr1:a,b,c,d,1,2,3
arr1:b,c
arr1:a,d,1,2,3
arr1:
arr1:a,d,c,d,e,f,1,2,3
arr1:e,f,1,2,3
arr1:a,d,c,d
/**
* 9.sort():对数组成员进行排序,默认是按照字典顺序排序。排序后,原数组将被改变。
* sort方法不是按照大小排序,而是按照对应字符串的字典顺序排序。也就是说,数值会被先转成字符串,再按照字典顺序进行比较,所以101排在11的前面。
*/
let arr1 = ["a","b","e","f","c","d"];
let arr2 = [1,2,9,3,4,5];
let arr3 = [111, 1101, 10111];
console.log("arr1:" + arr1.sort());
console.log("arr1:" + arr2.sort());
console.log("arr1:" + arr3.sort());
输出:
arr1:a,b,c,d,e,f
arr1:1,2,3,4,5,9
arr1:10111,1101,111
如果想让sort方法按照自定义方式排序,可以传入一个函数作为参数,表示按照自定义方法进行排序。该函数本身又接受两个参数,表示进行比较的两个元素。
如果返回值大于0,表示第一个元素排在第二个元素后面;其他情况下,都是第一个元素排在第二个元素前面。
let arr1 = [10111, 1101, 111];
let arr2 = [
{ name: "张三", age: 30 },
{ name: "李四", age: 24 },
{ name: "王五", age: 28 }
]
arr1.sort(function (a, b) {
return a - b;
})
arr2.sort(function (o1, o2) {
return o1.age - o2.age;
})
console.log("arr1:" + arr1);
console.log(arr2);
输出:
arr1:111,1101,10111
[ { name: '李四', age: 24 },
{ name: '王五', age: 28 },
{ name: '张三', age: 30 } ]
/**
* 10.map():对数组的所有成员依次调用一个函数,根据函数结果返回一个新数组。
*/
let arr1 = [1, 2, 3];
let arr2 = arr1.map(function (n) {
return n + "s";
});
console.log("arr1:" + arr1);
console.log("arr1:" + arr2);
输出:
arr1:1,2,3
arr1:1s,2s,3s
/**
* 11.filter():参数是一个函数,所有数组成员依次执行该函数,返回结果为true的成员组成一个新数组返回。该方法不会改变原数组。
*对比filter与map的输出区别
*/
let arr1 = [1, 2, 3, 4, 5];
let arr2 = arr1.map(function (n) {
return n>2;
});
let arr3 = arr1.filter(function (n){
return n>2;
});
console.log("arr1:" + arr1);
console.log("arr1:" + arr2);
console.log("arr1:" + arr3);
输出:
arr1:1,2,3,4,5
arr1:false,false,true,true,true
arr1:3,4,5