var aa = [1, 2, 3, 4, 4, 5, 6, 6];
var bb = aa.filter((item, index, self) =>
self.indexOf(item) === index
)
console.log(bb); // [1, 2, 3, 4, 5, 6]
ES6数组去重写法:
var arr = [1, 2, 3, 4, 4, 5, 6, 6];
var set = new Set(arr);
var newArr = Array.from(set);
console.log(newArr); // [1, 2, 3, 4, 5,6]
2.map() 不会改变原始数组,新数组中的元素为按原始数组顺序依次处理元素后的值,同样有两种写法
var aa = [1, 2, 3, 4, 4, 5, 6, 6];
var bb = aa.map((item) => {
return item = item * item
})
console.log(bb); // [1, 4, 9, 16, 16, 25, 36, 36]
3.every() 不会改变原始数组,检测数组所有元素是否都符合指定条件,全部通过返回true,否则返回false(所有项满足返回true)
- 如果数组中检测到有一个元素不满足,则整个表达式返回 false ,且剩余的元素不会再进行检测
- 如果所有元素都满足条件,则返回 true
var aa = [1, 2, 3, 4, 4, 5, 6, 6];
var bb = aa.every((item) => {
return item != 3
})
console.log(bb); // false
4.some() 不会改变原始数组,检测数组中的元素是否满足指定条件,只要有一个通过返回true,否则返回false(只要一项满足返回true)
- 如果有一个元素满足条件,则表达式返回true , 剩余的元素不会再执行检测
- 如果没有满足条件的元素,则返回false
var aa = [1, 2, 3, 4, 4, 5, 6, 6];
var bb = aa.some((item) => {
return item != 3
})
console.log(bb); // true