數(shù)組去重可以有六種方法
聲明:所有文章都是轉(zhuǎn)載整理的,只是為了自己學(xué)習(xí),方便自己觀看,如有侵權(quán),請(qǐng)立即聯(lián)系我,謝謝~
- 第一種方法用set內(nèi)的值不可重復(fù)的屬性禾酱;
const array = [1, 4, 6, 4, 64, 4, 478]
function uniqueuseset(arr) {
return Array.from([...new Set(arr)]);
}
- 對(duì)象是一種以鍵值對(duì)存儲(chǔ)信息的結(jié)構(gòu),并且不能有重復(fù)的鍵
function uniqueobject(arr) {
let obj = {},
len = arr.length;
for (let i = 0; i < len; i++) {
if (arr[i] in obj) {
obj[arr[i]]++;
} else {
obj[arr[i]] = 10;
}
}
return Object.keys(obj)
}
3.可以用js的filter方法;
var uniquefiltersimp = arr => (arr.filter((item, index, arr) => (arr.indexOf(item) === index)))
function uniquefilter(arr) {
return arr.filter((item, index, arr) => {
return arr.indexOf(item) === index;
});
}
4.可以用雙重for循環(huán)
function uniquefor(arr) {
for (let i = 0; i < arr.length; i++) {
for (let j = i + 1; j < arr.length; j++) {
if (Object.is(arr[i], arr[j])) {
arr.splice(j, 1);
j--;
}
}
}
return arr
}
5.使用indexOf()涌乳,可以判斷一個(gè)數(shù)組中是否包含某個(gè)值己英,如果存在則返回該元素在數(shù)組中的位置,如果不存在則返回-1夸溶。
function uniqueindex(arr){
let res = []
for (let i = 0; i < arr.length; i++) {
if (res.indexOf(arr[i]) === -1) {
res.push(arr[i])
}
}
return res
}
console.log(uniqueindex(arr))
6.js的include方法去重
function uniqueinclude(arr) {
let res = []
for (let i = 0; i < arr.length; i++) {
if (!res.includes(arr[i])) {
res.push(arr[i])
}
}
return res
}