首頁 > web前端 > js教程 > 主體

JavaScript數組去重的幾種方法分享

小云云
發布: 2018-02-08 11:40:59
原創
1580 人瀏覽過

陣列去重,一般需求是給你一個數組,呼叫去重方法,回傳數值副本,副本中沒有重複元素。一般來說,兩個元素透過=== 比較傳回true 的視為相同元素,需要去重,所以,1 和"1" 是不同的元素,1 和new Number(1) 是不同的元素,{}和{} 是不同的元素(引用不同)。 (當然如果需求認為 {} 和 {} 算是相同的元素,那麼解法就不一樣了),本文主要和大家分享JavaScript數組去重的幾種方法。

method 1

使用兩重循環

function unique(arr) {
 var res = [];
 for(var i = 0, len = arr.length;i < len; i++) {
  var item = arr[i];
  for(var j = 0, jLen = res.length; j<jLen; j++) {
   if(item == res[j]) break;
  }
  if(j == jLen) res.push(item);
 }
 return res;
}
登入後複製

method 2

function unique(arr) {
 var ret = []
 for (var i = 0; i < arr.length; i++) {
 var item = arr[i]
 if (ret.indexOf(item) === -1) {
  ret.push(item)
 }
 }
 return ret
}
登入後複製

這裡判斷可以使用一個語法糖

function unique(arr) {
 var res = [];
 for(var i = 0, len = arr.length;i < len; i++) {
  var item = arr[i];
  (res.indexOf(item) === -1) && res.push(item);
 }
 return res;
}
登入後複製

但是在低版本瀏覽器並沒有indexOf

var indexOf = [].indexOf ?
 function(arr, item) {
  return arr.indexOf(item)
 } :
 function indexOf(arr, item) {
  for (var i = 0; i < arr.length; i++) {
  if (arr[i] === item) {
   return i
  }
  }
  return -1
 }
function unique(arr) {
 var ret = []
 for (var i = 0; i < arr.length; i++) {
 var item = arr[i]
 if (indexOf(ret, item) === -1) {
  ret.push(item)
 }
 }
 return ret
}
登入後複製

method3

使用兩重循環的另外一種比較方式,前面是將原始數組的元素和結果數組一一比較,下面我們可以將原始數組的重複元素的最後一個元素放入數組中

function unique(arr) {
 var ret = [];
 var len = arr.length;
 var isRepeat;
 for(var i=0; i<len; i++) {
  isRepeat = false;
  for(var j=i+1; j<len; j++) {
   if(arr[i] === arr[j]){
    isRepeat = true;
    break;
   }
  }
  if(!isRepeat){
   ret.push(arr[i]);
  }
 }
 return ret;
}
登入後複製

這裡還有一個優化的版本

function unique(a) {
 var res = [];
 for (var i = 0, len = a.length; i < len; i++) {
 for (var j = i + 1; j < len; j++) {
  // 这一步十分巧妙
  // 如果发现相同元素
  // 则 i 自增进入下一个循环比较
  if (a[i] === a[j])
  j = ++i; //j = i = i + 1;
 }
 res.push(a[i]);
 }
 return res;
}
登入後複製

method4

用javascript 中的object 物件來當作哈希表

function dedup(arr) {
 var hashTable = {};
 return arr.filter(function(value,index,arr){
  var key = JSON.stringify(value);
  var match = Boolean(hashTable[key]);
  return (match ? false : hashTable[key] = true);
 });
}
登入後複製

因為Object 的key 值都是String 類型,所以對於1 和"1" 無法分別,我們可以稍微改進下,將類型也存入key 中

function dedup(arr) {
 var ret = [];
 var hash = {};
 for(var i = 0; i < arr.length; i++) {
  var item = arr[i];
  var key = typeof(item) + item;
  if(hash[key] !== 1) {
   ret.push(item)
   hash[key] = 1;
  }
 }
 return ret;
}
登入後複製

相關推薦:

PHP實作陣列去重的方法代碼

#JS簡單實作陣列去重的方法分析

############################################### ###jQuery簡單實作對陣列去重及排序運算詳解#######

以上是JavaScript數組去重的幾種方法分享的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!