国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > JS > 正文

JS實(shí)現(xiàn)數(shù)組去重方法總結(jié)(六種方法)

2024-05-06 16:38:24
字體:
供稿:網(wǎng)友

方法一:

雙層循環(huán),外層循環(huán)元素,內(nèi)層循環(huán)時(shí)比較值

如果有相同的值則跳過,不相同則push進(jìn)數(shù)組

js;">Array.prototype.distinct = function(){  var arr = this,    result = [],    i,    j,    len = arr.length;  for(i = 0; i < len; i++){    for(j = i + 1; j < len; j++){      if(arr[i] === arr[j]){        j = ++i;      }    }    result.push(arr[i]);  }  return result;}var arra = [1,2,3,4,4,1,1,2,1,1,1];arra.distinct();       //返回[3,4,2,1]

方法二:利用splice直接在原數(shù)組進(jìn)行操作

雙層循環(huán),外層循環(huán)元素,內(nèi)層循環(huán)時(shí)比較值

值相同時(shí),則刪去這個(gè)值

注意點(diǎn):刪除元素之后,需要將數(shù)組的長度也減1.

Array.prototype.distinct = function (){  var arr = this,    i,    j,    len = arr.length;  for(i = 0; i < len; i++){    for(j = i + 1; j < len; j++){      if(arr[i] == arr[j]){        arr.splice(j,1);        len--;        j--;      }    }  }  return arr;};var a = [1,2,3,4,5,6,5,3,2,4,56,4,1,2,1,1,1,1,1,1,];var b = a.distinct();console.log(b.toString()); //1,2,3,4,5,6,56

優(yōu)點(diǎn):簡單易懂

缺點(diǎn):占用內(nèi)存高,速度慢

方法三:利用對象的屬性不能相同的特點(diǎn)進(jìn)行去重

Array.prototype.distinct = function (){  var arr = this,    i,    obj = {},    result = [],    len = arr.length;  for(i = 0; i< arr.length; i++){    if(!obj[arr[i]]){  //如果能查找到,證明數(shù)組元素重復(fù)了      obj[arr[i]] = 1;      result.push(arr[i]);    }  }  return result;};var a = [1,2,3,4,5,6,5,3,2,4,56,4,1,2,1,1,1,1,1,1,];var b = a.distinct();console.log(b.toString()); //1,2,3,4,5,6,56

方法四:數(shù)組遞歸去重

運(yùn)用遞歸的思想

先排序,然后從最后開始比較,遇到相同,則刪除

Array.prototype.distinct = function (){  var arr = this,    len = arr.length;  arr.sort(function(a,b){    //對數(shù)組進(jìn)行排序才能方便比較    return a - b;  })  function loop(index){    if(index >= 1){      if(arr[index] === arr[index-1]){        arr.splice(index,1);      }      loop(index - 1);  //遞歸loop函數(shù)進(jìn)行去重    }  }  loop(len-1);  return arr;};var a = [1,2,3,4,5,6,5,3,2,4,56,4,1,2,1,1,1,1,1,1,56,45,56];var b = a.distinct();console.log(b.toString());    //1,2,3,4,5,6,45,56

方法五:利用indexOf以及forEach

Array.prototype.distinct = function (){  var arr = this,    result = [],    len = arr.length;  arr.forEach(function(v, i ,arr){    //這里利用map,filter方法也可以實(shí)現(xiàn)    var bool = arr.indexOf(v,i+1);    //從傳入?yún)?shù)的下一個(gè)索引值開始尋找是否存在重復(fù)    if(bool === -1){      result.push(v);    }  })  return result;};var a = [1,1,1,1,1,1,1,1,1,2,2,2,2,2,2,3,3,3,3,3,3,3,2,3,3,2,2,1,23,1,23,2,3,2,3,2,3];var b = a.distinct();console.log(b.toString());  //1,23,2,3

方法六:利用ES6的set

Set數(shù)據(jù)結(jié)構(gòu),它類似于數(shù)組,其成員的值都是唯一的。

利用Array.from將Set結(jié)構(gòu)轉(zhuǎn)換成數(shù)組

function dedupe(array){  return Array.from(new Set(array));}dedupe([1,1,2,3]) //[1,2,3]

拓展運(yùn)算符(...)內(nèi)部使用for...of循環(huán)

let arr = [1,2,3,3];let resultarr = [...new Set(arr)];  console.log(resultarr); //[1,2,3]

以上所述是小編給大家介紹的JS實(shí)現(xiàn)數(shù)組去重方法總結(jié)(六種方法),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對VeVb武林網(wǎng)網(wǎng)站的支持!


注:相關(guān)教程知識(shí)閱讀請移步到JavaScript/Ajax教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 蚌埠市| 馆陶县| 麻阳| 伊宁市| 周宁县| 曲沃县| 雷山县| 台山市| 搜索| 仁布县| 昌乐县| 汉寿县| 汉源县| 灵川县| 罗平县| 湾仔区| 滨海县| 乌拉特中旗| 南木林县| 黄陵县| 齐河县| 抚州市| 正定县| 彭阳县| 泌阳县| 辽阳县| 达州市| 扎鲁特旗| 鄂尔多斯市| 运城市| 简阳市| 武山县| 诏安县| 双桥区| 张掖市| 嵩明县| 田东县| 绥宁县| 项城市| 临江市| 财经|