JavaScript常見的五種數組去重的方式_javascript技巧

來源:互聯網
上載者:User

大致介紹

JavaScript的數組去重問題在許多面試中都會遇到,現在做個總結

先來建立一個數組

var arr = [1,2,3,3,2,'我','我',34,'我的',NaN,NaN];

第一種

思路:建立一個臨時數組,用for迴圈去依次判斷arr中的每個項在臨時數組中是否有相同的值,如果沒有則將這個值添加到臨時數組,如果有相同的值則不添加,最後返回這個臨時數組

代碼:

Array.prototype.removeDuplicate = function(){  var n = [];  for(var i=0;i<this.length;i++){  if(n.indexOf(this[i]) == -1 ){  n.push(this[i]);  }  } return n;}var m = arr.removeDuplicate();console.log(m);//[1, 2, 3, "我", 34, "我的", NaN, NaN]

注意:不會去掉重複的NaN值

第二種   

思路:建立一個臨時數組,用for迴圈利用indexOf()方法去依次判斷arr中的每個項在arr中第一次出現的位置,如果這個項在arr中第一次出現的位置就是它的位置,表明在它之前沒有相同的值則把它添加到臨時數組中,如果這個項在arr中第一次出現的位置不是他的位置則表明在它之前有相同的值,則不把他添加到臨時數組中;最後返回臨時數組

代碼:

Array.prototype.removeDuplicate = function(){  var n = [];  for(var i=0;i<this.length-1;i++){  if(this.indexOf(this[i]) == i){  n.push(this[i]);  }  } return n; } var m = arr.removeDuplicate(); console.log(m);//[1, 2, 3, "我", 34, "我的"]

注意:會把NaN值刪除

第三種

思路:建立一個臨時對象,利用for迴圈檢測這個臨時對象有沒有arr[i]這個屬性,如果沒有這個屬性工作表明arr[i]在它之前沒有和它重複的值。把臨時對象的arr[i]屬性設定為true,表明有這個屬性並把這個項添加到臨時數組中;最後返回臨時數組

代碼:

Array.prototype.removeDuplicate = function(){  var n = [],m = {};  for(var i=0;i<this.length;i++){  if(!m[this[i]]){  m[this[i]] = true;  n.push(this[i]);  }  } return n; }var m = arr.removeDuplicate();console.log(m);//[1, 2, 3, "我", 34, "我的", NaN]

第四種

思路:先將這個數組排序,然後比較每個項和它後面的項的值是否相等,如果不相等則添加到臨時數組中;最後返回臨時數組

代碼:

Array.prototype.removeDuplicate = function(){ var n = []; this.sort(); for(var i=0;i<this.length;i++){ if(this[i] != this[i+1]){  n.push(this[i]);  } } return n; }var m = arr.removeDuplicate();console.log(m);//[1, 2, 3, 34, NaN, NaN, "我", "我的"]

注意:不會去掉重複的NaN值

第五種

思路:利用ES6的方法set方法去重,並用Array.from轉換為數組

set是一種新的資料結構,它可以接收一個數組或者是類數組對象,自動去重其中的重複項目,返回一個對象

代碼:

Array.prototype.removeDuplicate = function(){ return (Array.from(new Set(this))); } var m = arr.removeDuplicate(); console.log(m);//[1, 2, 3, "我", 34, "我的", NaN]

以上就是本文的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的協助,同時也希望多多支援雲棲社區!

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.