400-650-7353
您所在的位置:首頁 > IT干貨資料 > web前端 > 【Web前端基礎知識】數組去重的方法

【Web前端基礎知識】數組去重的方法

  • 發布: 優就業it培訓
  • 來源:優就業
  • 2021-06-18 17:12:08
  • 閱讀()
  • 分享
  • 手機端入口

無論是在面試還是實際寫代碼中都會經常遇到數組去重,那接下來我們介紹幾種數組去重的方法。

  1. var arr = [3,6,4,1,8,8,8,8,8,4,0,9,2,7,8,5,3,4,8,9,3]; 

1、第一種是聲明一個空數組,通過indexOf( )查找的方法,判斷這個新數組中有沒有該元素,如果沒有即查找結果為 -1 時,將這個元素添加到新數組的末尾。

js代碼為:

  1. //1.創建一個空數組,把arr里面的元素往空對象中添加,判斷如果空數組沒有這個元素,加 
  2.        var array = []; 
  3.        for( var i = 0; i<arr.length; i++ ) { 
  4.            if( array.indexOf(arr[i]) == -1 ) { 
  5.                array.push( arr[i] ); 
  6.            } 
  7.        } 
  8.         console.log(array); 

2、第二種是操作數組自身:

從第一項開始,拿該項和后面的所有項作比較,如果后面有和比較項相等的,就把后面的一項刪除。刪除的方法會改變當前數組的長度,后面的元素會自動往前挪,所以補位上來的元素需要在進行一次比較,讓下標進行自減操作。

比較的詳細過程即是為:

拿數組中第一個元素,和后面所有的元素進行比較,如果一樣刪除后面哪一個

拿數組中第二個元素,和后面所有的元素進行比較,如果一樣刪除后面哪一個

...

數組中所有的元素后需要和后面的進行比較,所以需要進行for循環的嵌套

代碼為:

  1. for(var i = 0; i<arr.length; i++) { 
  2.             //和后面所有的元素進行比較 
  3.             for(var j = i+1; j<arr.length; j++) { 
  4.                 if( arr[i] == arr[j] ){ //重復,刪除后面的元素 
  5.                     arr.splice(j,1); 
  6.                     j--;  
  7. //刪除一個元素后元素位置會自動往前挪,下標也需要往前j-- 
  8.                 } 
  9.             } 
  10.         } 
  11.         console.log(arr); 

3、先使用sort()方法對數組進行排序,再比較看數組是否和相鄰的項相等,如果不同則存入新數組中

  1. // 先對數組進行sort排序 
  2.  var sortArr = arr.sort(); 
  3. // 初始化結果數組并存一個值 
  4.             var res = [sortArr[0]]; 
  5. // 循環遍歷數組進行比較 
  6.             for (var i = 1; i < sortArr.length; i++) { 
  7. // 如果當前的比較項與結果數組的最后一項不相等則放入 
  8.                 if (sortArr[i] !== res[res.length - 1]) { 
  9.                     res.push(sortArr[i]); 
  10.                 } 
  11.             } 
  12.             console.log(res); 

 

文章“【Web前端基礎知識】數組去重的方法”已幫助

更多內容

>>本文地址:http://www.028benet.com/zhuanye/2021/69054.html

THE END  

聲明:本站稿件版權均屬中公教育優就業所有,未經許可不得擅自轉載。

1 您的年齡

2 您的學歷

3 您更想做哪個方向的工作?

獲取測試結果
  • 大前端大前端
  • 大數據大數據
  • 互聯網營銷互聯網營銷
  • JavaJava
  • Linux云計算Linux
  • Python+人工智能Python
  • 嵌入式物聯網嵌入式
  • 全域電商運營全域電商運營
  • 軟件測試軟件測試
  • 室內設計室內設計
  • 平面設計平面設計
  • 電商設計電商設計
  • 網頁設計網頁設計
  • 全鏈路UI/UE設計UI設計
  • VR/AR游戲開發VR/AR
  • 網絡安全網絡安全
  • 新媒體與短視頻運營新媒體
  • 直播帶貨直播帶貨
  • 智能機器人軟件開發智能機器人
 

快速通道fast track

近期開班時間TIME

主站蜘蛛池模板: 超级乱淫视频aⅴ播放视频| 三上悠亚亚洲一区高清| 精品国产一区二区三区久久狼| 大地资源视频在线观看| 亚洲熟妇无码乱子av电影| 91丨九色丨首页在线观看| 日本国产中文字幕| 再来一次好吗动漫免费观看| 97色偷偷色噜噜狠狠爱网站| 最新国产在线播放| 喜欢老头吃我奶躁我的动图| 99re国产视频| 日本欧美视频在线| 免费va在线观看| 色五五月五月开| 成在人线av无码免费高潮水| 亚洲精品成a人在线观看| 成人禁在线观看| 婷婷四房综合激情五月在线| 亚洲午夜久久久久妓女影院| 芭蕉私人影院在线观看| 在线视频免费国产成人| 久久精品国产清高在天天线| 积积对积积的桶120分钟| 国产福利影院在线观看| 亚洲老妈激情一区二区三区| 国产精品乳摇在线播放| 娜露温泉无删减视频在线看 | 国产精品亚洲欧美云霸高清| 久久99蜜桃精品久久久久小说| 波多野结衣痴女系列88| 国产在线98福利播放视频免费| free哆啪啪免费永久| 日韩欧美中文字幕出| 伊人久久大香线蕉亚洲| 黄页免费视频播放在线播放| 女人与zozo| 久久精品国产99国产精2020丨| 男人扒开女人的腿做爽爽视频| 国产在线麻豆精品观看| 99爱在线视频|