數(shù)組去重的場景
將數(shù)組var arr =[1,1,‘true',‘true',true,true,66,66,false,false,undefined,undefined, null,null, NaN, NaN, 0, 0, ‘a', ‘a',{},{}]
中重復(fù)的值過濾掉
1、ES6-set
使用ES6中的set是最簡單的去重方法
1
2
3
4
5
6
7
|
<script> var arr=[ 1 , 2 , 3 , 4 , 1 , 2 , 3 ] //先將數(shù)組轉(zhuǎn)換為set var set= new Set(arr) //再將set轉(zhuǎn)換為數(shù)組 console.log(Array.from(set)) </script> |
2、利用Map數(shù)據(jù)結(jié)構(gòu)去重
創(chuàng)建一個空Map數(shù)據(jù)結(jié)構(gòu),遍歷需要去重的數(shù)組,把數(shù)組的每一個元素作為key存到Map中。由于Map中不會出現(xiàn)相同的key值,所以最終得到的就是去重后的結(jié)果
1
2
3
4
5
6
7
8
9
10
11
12
13
|
function shuzu(arr) { let map = new Map(); let array = new Array(); // 數(shù)組用于返回結(jié)果 for (let i = 0 ; i < arr.length; i++) { if (map .has(arr[i])) { // 如果有該key值 map .set(arr[i], true ); } else { map .set(arr[i], false ); // 如果沒有該key值 array .push(arr[i]); } } return array ; } |
3、 嵌套循環(huán)+splice
1
2
3
4
5
6
7
8
9
10
|
function shuzu(arr){ for (var i = 0 ; i < arr.length; i++){ for ( var j = i + 1 ; j < arr.length; j++){ if ( arr[i] === arr[j] ){ arr.splice(j, 1 ); } } } return arr; } |
4、 forEach + indexOf
1
2
3
4
5
6
7
8
9
|
function shuzu(arr){ var res = []; arr.forEach((val,index)=>{ if ( res.indexOf(val) === - 1 ){ res.push(val); } }); return res; } |
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注服務(wù)器之家的更多內(nèi)容!
原文鏈接:https://blog.csdn.net/WangYong_Z/article/details/121023560