数组去重

数组去重的方法

var arr = [1, 2, 3, 4, 5, 1, 2, 3, 4, 5]
let newArr = []

// 第一种
Array.from(new Set(arr))

// 第二种
let obj = {}
for (let i = 0; i < arr.length; i++) {
    if (!obj[arr[i]]) {
        newArr.push(arr[i])
        obj[arr[i]] = 1
    }
}

// 第三种
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--
        }
    }
}

// 第四种
arr.forEach((v) => {
    if (newArr.indexOf(v) == -1) newArr.push(v)
})

// 第五种
arr.forEach((v) => {
    if (!newArr.includes(v)) newArr.push(v)
})

// 第六种
arr.sort()
arr.forEach((v, i) => {
    if (arr[i] !== arr[i - 1]) newArr.push(v)
})

// 第七种
arr.sort()
for (let i = 0; i < arr.length; i++) {
    if (arr[i] !== arr[i - 1]) newArr.push(v)
}

// 第八种
for (let i = 0; i < arr.length; i++) {
    if (newArr.indexOf(arr[i] == -1)) newArr.push(arr[i])
}

// 第九种
for (let i = 0; i < arr.length; i++) {
    if (!newArr.includes(arr[i])) newArr.push(arr[i])
}

// 第十种
arr.filter((v, i) => arr.indexOf(v) == i)

// 第十一种
arr.reduce((newArr, v) => {
    if (newArr.indexOf(v) == -1) {
        newArr.push(v)
    }
    return newArr
}, [])

// 第十二种
arr.reduce((newArr, v) => {
    if (!newArr.includes) {
        newArr.push(v)
    }
    return newArr
}, [])

// 第十三种
let obj = {}
arr.forEach((v) => {
    if (!obj[v]) {
        newArr.push(v)
        obj[v] = 1
    }
})
// 第十四种
let newArr = [...new Set(arr)]

你可能感兴趣的:(前端,javascript)