欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript數(shù)組去重的多種方法(四種)

 更新時間:2017年09月19日 09:08:49   投稿:mrr  
數(shù)組去重,一般需求是給你一個數(shù)組,調(diào)用去重方法,返回數(shù)值副本,副本中沒有重復元素。下面腳本之家小編給大家?guī)砹薺s數(shù)組去重的多種方法,非常不錯,需要的朋友參考下

數(shù)組去重,一般需求是給你一個數(shù)組,調(diào)用去重方法,返回數(shù)值副本,副本中沒有重復元素。一般來說,兩個元素通過 === 比較返回 true 的視為相同元素,需要去重,所以,1 和 "1" 是不同的元素,1 和 new Number(1) 是不同的元素,{} 和 {} 是不同的元素(引用不同)。(當然如果需求認為 {} 和 {} 算作相同的元素,那么解法就不一樣了)

method 1

使用兩重循環(huán)

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

使用兩重循環(huán)的另外一種比較方式,前面是將原數(shù)組的元素和結果數(shù)組一一比較,下面我們可以將原數(shù)組的重復元素的最后一個元素放入數(shù)組中

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;
}

這里還有一個優(yōu)化的版本

function unique(a) {
 var res = [];
 for (var i = 0, len = a.length; i < len; i++) {
 for (var j = i + 1; j < len; j++) {
  // 這一步十分巧妙
  // 如果發(fā)現(xiàn)相同元素
  // 則 i 自增進入下一個循環(huán)比較
  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;
}

總結

以上所述是小編給大家介紹的JavaScript數(shù)組去重的多種方法(四種),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關文章

  • 詳解如何用JavaScript編寫一個單元測試

    詳解如何用JavaScript編寫一個單元測試

    測試代碼是確保代碼穩(wěn)定的第一步。能做到這一點的最佳方法之一就是使用單元測試。這篇文章主要介紹了如何用JavaScript編寫你的第一個單元測試,感興趣的可以了解一下
    2022-11-11
  • JavaScript中跨域問題的深入理解

    JavaScript中跨域問題的深入理解

    這篇文章主要給大家介紹了關于JavaScript中跨域問題的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-03-03
  • JavaScript實現(xiàn)復制內(nèi)容到粘貼板代碼

    JavaScript實現(xiàn)復制內(nèi)容到粘貼板代碼

    最近做了一個前端項目,其中有需求:通過button直接把input或者textarea里的值復制到粘貼板里。下面小編給大家分享JavaScript實現(xiàn)復制內(nèi)容到粘貼板代碼,需要的朋友參考下
    2016-03-03
  • 如何使用pm2快速將項目部署到遠程服務器

    如何使用pm2快速將項目部署到遠程服務器

    這篇文章主要介紹了如何使用pm2快速將項目部署到遠程服務器,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-03-03
  • js中this的用法實例分析

    js中this的用法實例分析

    這篇文章主要介紹了js中this的用法,實例分析了js中this的4種常見用法,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-01-01
  • 微信小程序JSON配置文件詳細講解作用

    微信小程序JSON配置文件詳細講解作用

    JSON是一種數(shù)據(jù)格式,在實際開發(fā)中,JSON總是以配置文件的形式出現(xiàn)。小程序項目中也不例外:通過不同的Json配置文件,可以對小程序項目進行不同級別的配置
    2022-10-10
  • 選擇復選框按鈕置灰否則按鈕可用

    選擇復選框按鈕置灰否則按鈕可用

    這篇文章主要介紹了使用js實現(xiàn)選擇復選框按鈕置灰否則按鈕可用,需要的朋友可以參考下
    2014-05-05
  • Element-plus安裝及基礎組件使用詳解

    Element-plus安裝及基礎組件使用詳解

    ElementPlus是一個基于Vue3的UI組件庫,旨在提供豐富的HTML元素封裝,以簡化前端開發(fā),主要特點包括預定義樣式、事件處理、易用性等,為開發(fā)者提供了一致且美觀的用戶界面,同時支持按需導入,提高項目效率,感興趣的朋友一起看看吧
    2024-09-09
  • 4個值得收藏的Javascript技巧

    4個值得收藏的Javascript技巧

    這篇文章主要介紹了4個值得收藏的Javascript技巧,文章首先通過變量轉字符串展開主題詳情,需要的小伙伴可以參考一下
    2022-07-07
  • webpack構建的詳細流程探底

    webpack構建的詳細流程探底

    目前,幾乎所有業(yè)務的開發(fā)構建都會用到 webpack 。所以下面這篇文章主要給大家介紹了關于webpack構建的詳細流程的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面來一起看看吧。
    2018-01-01

最新評論