摘要:提供了新的數據結構。它類似于數組,但是成員的值都是唯一的,沒有重復的值。思路為對象里沒有數組元素的屬性,就在對象里添加數組元素的屬性,并賦值為,然后在過濾。方法可返回某個指定的元素在數組中首次出現的位置。
1、es6 set
ES6 提供了新的數據結構 Set。它類似于數組,但是成員的值都是唯一的,沒有重復的值。
let arr = [1,2,3,4,3,2,3,4,6,7,6]; let unique = (arr)=> [...new Set(arr)]; unique(arr);//[1, 2, 3, 4, 6, 7]2、es6 map
思路為map對象里沒有數組元素的屬性,就在map對象里添加數組元素的屬性,并賦值為1,然后在過濾。
let arr = [1,2,3,4,3,2,3,4,6,7,6]; let unique = (arr)=> { let seen = new Map(); return arr.filter((item) => { return !seen.has(item) && seen.set(item,1); }); }; unique(arr);3、for 雙重循環
通過判斷第二層循環,去重的數組中是否含有該元素,如果有就退出第二層循環,如果沒有j==result.length就相等,然后把對應的元素添加到最后的數組里面。
let arr = [1,2,3,4,3,2,3,4,6,7,6]; let result = []; for(var i = 0 ; i < arr.length; i++) { for(var j = 0 ; j < result.length ; j++) { if( arr[i] === result[j]){ break; }; }; if(j == result.length){ result.push(arr[i]); }; }; console.log(result);4、indexOf
indexOf() 方法可返回某個指定的元素在數組中首次出現的位置。如果沒有就返回-1。
let arr = [1,2,3,4,3,2,3,4,6,7,6]; let unique = (arr) => { let result = []; for( var i = 0 ; i < arr.length ; i++){ if(result.indexOf(arr[i]) == -1){ result.push(arr[i]) } }; return result; }; unique(arr);5、indexOf filter
let arr = [1,2,3,4,3,2,3,4,6,7,6]; let unique = (arr) => { return arr.filter((item,index) => { return arr.indexOf(item) === index; }) }; unique(arr);6、排序后去重
先數組排序,然后判斷是否是第一個元素并且前一個元素是否和后一個元素相同,不同就加進新數組
let arr = [1,2,3,4,3,2,3,4,6,7,6]; let unique = (arr) => { let arrNew = arr.sort((a,b)=>a-b); let seen,result = []; for(var i = 0 ; i < arrNew.length ;i++){ if(!seen || seen != arrNew[i]){ result.push(arrNew[i]); }; seen = arrNew[i] }; return result; }; unique(arr);
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/104248.html
摘要:注方法可以返回某個指定字符串在字符串中首次出現的位置比如首次出現的位置是數組中的第一個,即下標為遍歷數組使用標識符去重聲明一個變量標識排序后遍歷過濾數組思路先給數組排序,這樣相同的項總是相鄰。 假設我們有數組arr,并且聲明新數組hash用來存放去重后的元素: var arr = [23,44,5,2,23,5,1,7,8,7]; //包含重復元素 var hash= [];...
摘要:階段該階段主要通過循環遍歷數組從而達到去重的目的多次循環去掉重復元素以下所有方法默認都那拿該數組進行測試結果如下圖可見除了沒有去掉,其他效果都還挺好。 數組去重經常被人拿來說事,雖然在工作中不常用,但他能夠很好的考察js基礎知識掌握的深度和廣度,下面從js的不同階段總結一下去重的方法。 ES3階段 該階段主要通過循環遍歷數組從而達到去重的目的 多次循環去掉重復元素 // 以下所有方法默...
摘要:數組去重看了網上很多數組去重方法,用的比較常見的大概就幾種,今天想自己來做一個總結。還有就是方法返回的數組也是排序后的數組,某些情況下可能不符合要求。 JS數組去重 看了網上很多數組去重方法,用的比較常見的大概就幾種,今天想自己來做一個總結。部分內容參考該博客 1 . 在原數組上操作(基本方法) 思路:利用循環嵌套,判斷數組中每個元素與其后面的元素是否相等,如果相等,就使用spli...
閱讀 1833·2021-11-25 09:43
閱讀 1335·2021-11-22 15:08
閱讀 3734·2021-11-22 09:34
閱讀 3225·2021-09-04 16:40
閱讀 3000·2021-09-04 16:40
閱讀 542·2019-08-30 15:54
閱讀 1334·2019-08-29 17:19
閱讀 1752·2019-08-28 18:13