1.Set()方法
Set()本身是个构造函数,他类似于数组,但成员是唯一的。
//set 数组去重
let arr = [1, 5, 6, 1, 2, 3, 4, 89, 15]
let newarr = [...new Set(arr)]
console.log(newarr);
2.indexOf方法
indexOf()可以查找第一次出现制定字符串的位置,返回一个数值指出该字符串的初始位置,如果没有该字符串返回 -1 。
// indexOf 数组去重
// indexOf 数组去重
let arr = [1, 5, 6, 1, 2, 3, 4, 89, 15]
function func(arr) {
let newarr = []
for (let i = 0; i < arr.length; i++) {
if (newarr.indexOf(arr[i]) === -1) {
newarr.push(arr[i])
}
}
return newarr
}
console.log(func(arr));
3.includes 方法
includes可以判断数组中是否又改值,如果有返回true,没有返回false
// includes
let arr = [1, 5, 6, 1, 2, 3, 4, 89, 15]
function func(arr) {
let newarr = []
for (let i = 0; i < arr.length; i++) {
if (!newarr.includes(arr[i])) {
newarr.push(arr[i])
}
}
return newarr
}
console.log(func(arr));
4.splice方法
splice可以删除数组中的元素,参数分别为起始元素索引,删除位数,添加的数据。
//splice
let arr = [1, 5, 6, 1, 2, 3, 4, 89, 15]
function func(arr) {
for (let i = 0; i < arr.length; i++) {
for (let j = i+1; j < arr.length; j++) {
if (arr[i] === arr[j]) {
arr.splice(j, 1)
j--
}
}
}
return arr
}
console.log(func(arr));
5.双层for循环
// 双重for循环
let arr = [1, 5, 6, 1, 2, 5, 4, 89, 15]
function func(arr) {
let newarr = []
for (let i = 0; i < arr.length; i++) {
let flag = true
for (let j = 0; j < newarr.length; j++) {
if (arr[i] == newarr[j]) {
flag = false
}
}
if (flag) {
newarr.push(arr[i])
}
}
return newarr
}
console.log(func(arr));
6.filter与indexOf配合
循环过滤出首个索引和当前索引一致的数据
// filter indexOf
let arr = [1, 5, 6, 1, 2, 5, 4, 89, 15]
function func(arr) {
const newarr = arr.filter((item, index) => {
return arr.indexOf(item) === index
})
return newarr
}
console.log(func(arr));
7.map
1、has():检测map对象中键是否存在,存在返回true,不存在返回false。
2、set():为map对象添加键值对,参数为(键,值),如果只传入一个参数,则值为undefined。
3、get():通过键来获取对应的值。
// map
let map = new Map()
let arr = [1, 5, 6, 1, 2, 5, 4, 89, 15]
function func(arr) {
let newarr = []
for (let i = 0; i < arr.length; i++){
if (!map.has(arr[i])) {
map.set(arr[i], true)
newarr.push(arr[i])
}
}
return newarr
}
console.log(func(arr));
8.reduce
当前值若在pre中不存在就push到pre中
// reduce
let arr = [1, 5, 6, 1, 2, 5, 4, 89, 15]
function func(arr) {
let newarr = arr.reduce((pre, cur) => {
if (!pre.includes(cur)) {
pre.push(cur)
}
return pre
}, [])
return newarr
}
console.log(func(arr));