1、删除数组里指定的某个元素
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
var arr = [3,2,3,3,5,3],
val = 3;
var removeElement = function(arr, elm) {
for (var i = 0; i < arr.length; i++) {
if (arr[i] == elm) {
arr.splice(i, 1);
i--;
}
}
return arr;
};
console.log(removeElement(arr, val)); // [2, 5]
|
注意:这里for循环里的length是动态的,随着splice删除数组元素而变小,这里不能用forEach,因为forEach方法它一开始执行就自动缓存数组的长度,删除数组元素会出现意外。
2、数组去重的方法
第一种,双重遍历去重法
- 构建一个新的数组存放结果
- for循环中每次从原数组中取出一个元素,用这个元素循环与结果数组对比
- 若结果数组中没有该元素,则存到结果数组中
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
// 去除数组里的重复元素
function unique(arr) {
var ret = [];
var len = arr.length;
var isRepeat;
for(var i=0; i<len; i++) {
isRepeat = false;
for(var j=i+1; j<len; j++) {
if(arr[i] === arr[j]){
isRepeat = true;
break;
}
}
if(!isRepeat){
ret.push(arr[i]);
}
}
return ret;
}
var arr = [3, 3, 2, 3];
console.log(unique(arr)); // [2, 3]
|
第二种,对象键值对法
- 创建一个新的数组存放结果
- 创建一个空对象
- for循环时,每次取出一个元素与对象进行对比,如果这个元素不重复,则把它存放到结果数组中,同时把这个元素的内容作为对象的一个属性,并赋值为1,存入到第2步建立的对象中。
说明:至于如何对比,就是每次从原数组中取出一个元素,然后到对象中去访问这个属性,如果能访问到值,则说明重复。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
function unique(arr) {
var res = [];
var json = {};
for (var i = 0; i < arr.length; i++) {
if (!json[arr[i]]) {
res.push(arr[i]);
json[arr[i]] = 1;
}
}
return res;
}
var arr = [3, 3, 2, "3", "a", "a"];
console.log(unique(arr)); // [3, 2, "a"]
|
第三种,ES5方法
利用 ES5 里的方法, indexOf、filter
arr.indexOf(要查找的元素),返回被找到的元素在数组中的索引位置,如果没有则返回-1。
arr.filter(元素的值,元素的索引,被遍历的数组),返回一个通过测试的数组。
1
2
3
4
5
6
7
8
9
10
|
function unique(arr) {
var res = arr.filter(function(item, index, array) {
return array.indexOf(item) === index;
});
return res;
}
var arr = [1, 1, '1', '2', 1];
var ans = unique(arr);
console.log(ans); // => [1, "1", "2"]
|
第四种,ES6方法
ES6 部署了 Set 以及 Array.from 方法,如果浏览器支持,完全可以这样:
ES2015还引入了一种叫作Set的数据类型,它不允许重复元素出现,如果你重复添加同一个元素的话,Set中只会存在一个。
1
2
3
4
5
6
7
|
function unique(arr) {
return Array.from(new Set(arr));
}
var arr = [1, 2, "a", "1", 2 ,"a"];
console.log(unique(arr)) // [1, 2, "a", "1"]
|
关于数组去重更多详细方法参看
JavaScript 数组去重
数组去重 – JS Tips – A JS tip per day!
Remove Duplicates from JavaScript Array
从 JavaScript 数组去重谈性能优化
也谈 JavaScript 数组去重
3、取数组中最大值最小值
遍历比较方法
- 设一个变量存放最大值,将数组中第一个值赋值给该变量
- 遍历数组与最大值变量比较,如果大于最大值,则将该值赋值最大值变量
- 遍历结束后,变量里储存的就是数组里的最大值
1
2
3
4
5
6
7
8
9
10
11
12
|
function arrayMax(arr) {
var max = arr[0];
arr.forEach(function(v){
if(v > max) {
max = v
}
})
return max;
}
var arr = [1, 3, 45, 24, 8, 20];
console.log(arrayMax(arr)); // 45
|
利用 Math.max() 与 Math.min() 方法
将数组转换成参数传进Math.max()或Math.min()。
1
2
3
4
5
6
|
function max(arr) {
return Math.max.apply({},arr);
}
var arr = [1, 3, 45, 24, 8, 20];
console.log(max(arr)); // 45
|
ES5方法
- 利用数组实例的 reduce(function(prev,curv,index,arr)) 方法
- 依次比较回调函数中参数 prev 与 curv 的大小,返回大的那个
reduce(function(上一次调用回调返回的值, 数组中正在处理的元素, 当前元素索引, 调用reduce的数组))
1
2
3
4
5
6
7
8
9
|
function max(arr) {
return arr.reduce(function(prev,curv){
return prev > curv ? prev : curv
})
}
var arr = [1, 3, 45, 24, 8, 20];
console.log(max(arr)); // 45
|
4、多维数组扁平化
将多维数组"拍平”
将下列数组转为单一数组
1
|
var myArray = [[1, 2],[3, 4, 5], [6, 7, 8, 9]];
|
1、双层遍历法
1
2
3
4
5
6
7
8
|
var myArray = [[1, 2],[3, 4, 5], [6, 7, 8, 9]];
var newArray = [];
for (var i = 0; i < myArray.length; ++i) {
for (var j = 0; j < myArray[i].length; ++j)
newArray.push(myArray[i][j]);
}
console.log(newArray);
// [1, 2, 3, 4, 5, 6, 7, 8, 9]
|
2、使用concat()和apply()
1
2
3
4
5
|
var myArray = [[1, 2],[3, 4, 5], [6, 7, 8, 9]];
var newArray = [].concat.apply([], myArray);
console.log(newArray);
// [1, 2, 3, 4, 5, 6, 7, 8, 9]
|
3、使用reduce()
1
2
3
4
5
6
|
var myArray = [[1, 2],[3, 4, 5], [6, 7, 8, 9]];
var newArray = myArray.reduce(function(prev, curr) {
return prev.concat(curr);
});
console.log(newArray);
// [1, 2, 3, 4, 5, 6, 7, 8, 9]
|
4、使用 ES6 的展开运算符
1
2
3
4
|
var myArray = [[1, 2],[3, 4, 5], [6, 7, 8, 9]];
var newArray = [].concat(...myArray);
console.log(newArray);
// [1, 2, 3, 4, 5, 6, 7, 8, 9]
|
引用参考列表
MDN 的 JavaScript 标准库 Array 部分
Js Tips
撸js基础之数组
原文地址: http://zyj1022.github.io/posts/frontend/2017/js-array-issue.html
转载时必须以链接形式注明原始出处及本声明