国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

JavaScript數組去重的方法總結【12種方法,號稱史上最全】

2024-05-06 16:48:35
字體:
來源:轉載
供稿:網友

本文實例總結了JavaScript數組去重的方法。分享給大家供大家參考,具體如下:

數組去重,一般都是在面試的時候才會碰到,一般是要求手寫數組去重方法的代碼。如果是被提問到,數組去重的方法有哪些?你能答出其中的10種,面試官很有可能對你刮目相看。

在真實的項目中碰到的數組去重,一般都是后臺去處理,很少讓前端處理數組去重。雖然日常項目用到的概率比較低,但還是需要了解一下,以防面試的時候可能回被問到。

注:寫的匆忙,加上這幾天有點忙,還沒有非常認真核對過,不過思路是沒有問題,可能一些小細節出錯而已。

數組去重的方法

一、利用ES6 Set去重(ES6中最常用)

function unique (arr) { return Array.from(new Set(arr))}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];console.log(unique(arr)) //[1, "true", true, 15, false, undefined, null, NaN, "NaN", 0, "a", {}, {}]

不考慮兼容性,這種去重的方法代碼最少。這種方法還無法去掉“{}”空對象,后面的高階方法會添加去掉重復“{}”的方法。

二、利用for嵌套for,然后splice去重(ES5中最常用)

function unique(arr){    for(var i=0; i<arr.length; i++){      for(var j=i+1; j<arr.length; j++){        if(arr[i]==arr[j]){     //第一個等同于第二個,splice方法刪除第二個          arr.splice(j,1);          j--;        }      }    }return arr;}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];console.log(unique(arr))//[1, "true", 15, false, undefined, NaN, NaN, "NaN", "a", {…}, {…}]   //NaN和{}沒有去重,兩個null直接消失了

雙層循環,外層循環元素,內層循環時比較值。值相同時,則刪去這個值。

想快速學習更多常用的ES6語法,可以看我之前的文章《學習ES6筆記──工作中常用到的ES6語法》。

三、利用indexOf去重

function unique(arr) {  if (!Array.isArray(arr)) {    console.log('type error!')    return  }  var array = [];  for (var i = 0; i < arr.length; i++) {    if (array .indexOf(arr[i]) === -1) {      array .push(arr[i])    }  }  return array;}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];console.log(unique(arr))// [1, "true", true, 15, false, undefined, null, NaN, NaN, "NaN", 0, "a", {…}, {…}] //NaN、{}沒有去重

新建一個空的結果數組,for 循環原數組,判斷結果數組是否存在當前元素,如果有相同的值則跳過,不相同則push進數組。

四、利用sort()

function unique(arr) {  if (!Array.isArray(arr)) {    console.log('type error!')    return;  }  arr = arr.sort()  var arrry= [arr[0]];  for (var i = 1; i < arr.length; i++) {    if (arr[i] !== arr[i-1]) {      arrry.push(arr[i]);    }  }  return arrry;}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];console.log(unique(arr))// [0, 1, 15, "NaN", NaN, NaN, {…}, {…}, "a", false, null, true, "true", undefined]   //NaN、{}沒有去重

利用sort()排序方法,然后根據排序后的結果進行遍歷及相鄰元素比對。

五、利用對象的屬性不能相同的特點進行去重(這種數組去重的方法有問題,不建議用,有待改進)

function unique(arr) {  if (!Array.isArray(arr)) {    console.log('type error!')    return  }  var arrry= [];   var obj = {};  for (var i = 0; i < arr.length; i++) {    if (!obj[arr[i]]) {      arrry.push(arr[i])      obj[arr[i]] = 1    } else {      obj[arr[i]]++    }  }  return arrry;}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];console.log(unique(arr))//[1, "true", 15, false, undefined, null, NaN, 0, "a", {…}]  //兩個true直接去掉了,NaN和{}去重

六、利用includes

function unique(arr) {  if (!Array.isArray(arr)) {    console.log('type error!')    return  }  var array =[];  for(var i = 0; i < arr.length; i++) {      if( !array.includes( arr[i]) ) {//includes 檢測數組是否有某個值          array.push(arr[i]);       }  }  return array}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];console.log(unique(arr))//[1, "true", true, 15, false, undefined, null, NaN, "NaN", 0, "a", {…}, {…}]   //{}沒有去重

七、利用hasOwnProperty

function unique(arr) {  var obj = {};  return arr.filter(function(item, index, arr){    return obj.hasOwnProperty(typeof item + item) ? false : (obj[typeof item + item] = true)  })}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];console.log(unique(arr))//[1, "true", true, 15, false, undefined, null, NaN, "NaN", 0, "a", {…}]  //所有的都去重了

利用hasOwnProperty 判斷是否存在對象屬性

八、利用filter

function unique(arr) { return arr.filter(function(item, index, arr) {  //當前元素,在原始數組中的第一個索引==當前索引值,否則返回當前元素  return arr.indexOf(item, 0) === index; });}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];console.log(unique(arr))//[1, "true", true, 15, false, undefined, null, "NaN", 0, "a", {…}, {…}]

九、利用遞歸去重

function unique(arr) {    var array= arr;    var len = array.length;  array.sort(function(a,b){  //排序后更加方便去重    return a - b;  })  function loop(index){    if(index >= 1){      if(array[index] === array[index-1]){        array.splice(index,1);      }      loop(index - 1);  //遞歸loop,然后數組去重    }  }  loop(len-1);  return array;}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];console.log(unique(arr))//[1, "a", "true", true, 15, false, 1, {…}, null, NaN, NaN, "NaN", 0, "a", {…}, undefined]

十、利用Map數據結構去重

function arrayNonRepeatfy(arr) { let map = new Map(); let array = new Array(); // 數組用于返回結果 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 ;}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];console.log(unique(arr))//[1, "a", "true", true, 15, false, 1, {…}, null, NaN, NaN, "NaN", 0, "a", {…}, undefined]

創建一個空Map數據結構,遍歷需要去重的數組,把數組的每一個元素作為key存到Map中。由于Map中不會出現相同的key值,所以最終得到的就是去重后的結果。

十一、利用reduce+includes

function unique(arr){  return arr.reduce((prev,cur) => prev.includes(cur) ? prev : [...prev,cur],[]);}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];console.log(unique(arr));// [1, "true", true, 15, false, undefined, null, NaN, "NaN", 0, "a", {…}, {…}]

十二、[...new Set(arr)]

[...new Set(arr)]//代碼就是這么少----(其實,嚴格來說并不算是一種,相對于第一種方法來說只是簡化了代碼)

PS:有些文章提到了foreach+indexOf數組去重的方法,個人覺得都是大同小異,所以沒有寫上去。

希望本文所述對大家JavaScript程序設計有所幫助。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 两当县| 山阳县| 建宁县| 得荣县| 吴堡县| 灵璧县| 延吉市| 康保县| 类乌齐县| 梧州市| 雅安市| 山阴县| 浮山县| 如东县| 龙南县| 清苑县| 霸州市| 新沂市| 海盐县| 阿拉善盟| 南充市| 昌乐县| 新昌县| 云霄县| 三河市| 揭东县| 响水县| 桃源县| 万载县| 泰顺县| 昌邑市| 栖霞市| 怀化市| 武功县| 三穗县| 安塞县| 石阡县| 清河县| 武陟县| 秦安县| 漠河县|