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

首頁 > 編程 > JavaScript > 正文

JavaScript數組去重的方法總結【12種方法,號稱史上最全】

2019-11-19 12:03:42
字體:
來源:轉載
供稿:網友

本文實例總結了JavaScript數組去重的方法。分享給大家供大家參考,具體如下:

數組去重,一般都是在面試的時候才會碰到,一般是要求手寫數組去重方法的代碼。如果是被提問到,數組去重的方法有哪些?你能答出其中的10種,面試官很有可能對你刮目相看。

在真實的項目中碰到的數組去重,一般都是后臺去處理,很少讓前端處理數組去重。雖然日常項目用到的概率比較低,但還是需要了解一下,以防面試的時候可能回被問到。

注:寫的匆忙,加上這幾天有點忙,還沒有非常認真核對過,不過思路是沒有問題,可能一些小細節出錯而已。

數組去重的方法

一、利用ES6 Set去重(ES6中最常用)

function unique (arr) { return Array.from(new Set(arr))}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];console.log(unique(arr)) //[1, "true", true, 15, false, undefined, null, NaN, "NaN", 0, "a", {}, {}]

不考慮兼容性,這種去重的方法代碼最少。這種方法還無法去掉“{}”空對象,后面的高階方法會添加去掉重復“{}”的方法。

二、利用for嵌套for,然后splice去重(ES5中最常用)

function unique(arr){    for(var i=0; i<arr.length; i++){      for(var j=i+1; j<arr.length; j++){        if(arr[i]==arr[j]){     //第一個等同于第二個,splice方法刪除第二個          arr.splice(j,1);          j--;        }      }    }return arr;}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];console.log(unique(arr))//[1, "true", 15, false, undefined, NaN, NaN, "NaN", "a", {…}, {…}]   //NaN和{}沒有去重,兩個null直接消失了

雙層循環,外層循環元素,內層循環時比較值。值相同時,則刪去這個值。

想快速學習更多常用的ES6語法,可以看我之前的文章《學習ES6筆記──工作中常用到的ES6語法》。

三、利用indexOf去重

function unique(arr) {  if (!Array.isArray(arr)) {    console.log('type error!')    return  }  var array = [];  for (var i = 0; i < arr.length; i++) {    if (array .indexOf(arr[i]) === -1) {      array .push(arr[i])    }  }  return array;}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];console.log(unique(arr))// [1, "true", true, 15, false, undefined, null, NaN, NaN, "NaN", 0, "a", {…}, {…}] //NaN、{}沒有去重

新建一個空的結果數組,for 循環原數組,判斷結果數組是否存在當前元素,如果有相同的值則跳過,不相同則push進數組。

四、利用sort()

function unique(arr) {  if (!Array.isArray(arr)) {    console.log('type error!')    return;  }  arr = arr.sort()  var arrry= [arr[0]];  for (var i = 1; i < arr.length; i++) {    if (arr[i] !== arr[i-1]) {      arrry.push(arr[i]);    }  }  return arrry;}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];console.log(unique(arr))// [0, 1, 15, "NaN", NaN, NaN, {…}, {…}, "a", false, null, true, "true", undefined]   //NaN、{}沒有去重

利用sort()排序方法,然后根據排序后的結果進行遍歷及相鄰元素比對。

五、利用對象的屬性不能相同的特點進行去重(這種數組去重的方法有問題,不建議用,有待改進)

function unique(arr) {  if (!Array.isArray(arr)) {    console.log('type error!')    return  }  var arrry= [];   var obj = {};  for (var i = 0; i < arr.length; i++) {    if (!obj[arr[i]]) {      arrry.push(arr[i])      obj[arr[i]] = 1    } else {      obj[arr[i]]++    }  }  return arrry;}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];console.log(unique(arr))//[1, "true", 15, false, undefined, null, NaN, 0, "a", {…}]  //兩個true直接去掉了,NaN和{}去重

六、利用includes

function unique(arr) {  if (!Array.isArray(arr)) {    console.log('type error!')    return  }  var array =[];  for(var i = 0; i < arr.length; i++) {      if( !array.includes( arr[i]) ) {//includes 檢測數組是否有某個值          array.push(arr[i]);       }  }  return array}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];console.log(unique(arr))//[1, "true", true, 15, false, undefined, null, NaN, "NaN", 0, "a", {…}, {…}]   //{}沒有去重

七、利用hasOwnProperty

function unique(arr) {  var obj = {};  return arr.filter(function(item, index, arr){    return obj.hasOwnProperty(typeof item + item) ? false : (obj[typeof item + item] = true)  })}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];console.log(unique(arr))//[1, "true", true, 15, false, undefined, null, NaN, "NaN", 0, "a", {…}]  //所有的都去重了

利用hasOwnProperty 判斷是否存在對象屬性

八、利用filter

function unique(arr) { return arr.filter(function(item, index, arr) {  //當前元素,在原始數組中的第一個索引==當前索引值,否則返回當前元素  return arr.indexOf(item, 0) === index; });}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];console.log(unique(arr))//[1, "true", true, 15, false, undefined, null, "NaN", 0, "a", {…}, {…}]

九、利用遞歸去重

function unique(arr) {    var array= arr;    var len = array.length;  array.sort(function(a,b){  //排序后更加方便去重    return a - b;  })  function loop(index){    if(index >= 1){      if(array[index] === array[index-1]){        array.splice(index,1);      }      loop(index - 1);  //遞歸loop,然后數組去重    }  }  loop(len-1);  return array;}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];console.log(unique(arr))//[1, "a", "true", true, 15, false, 1, {…}, null, NaN, NaN, "NaN", 0, "a", {…}, undefined]

十、利用Map數據結構去重

function arrayNonRepeatfy(arr) { let map = new Map(); let array = new Array(); // 數組用于返回結果 for (let i = 0; i < arr.length; i++) {  if(map .has(arr[i])) { // 如果有該key值   map .set(arr[i], true);  } else {   map .set(arr[i], false);  // 如果沒有該key值   array .push(arr[i]);  } } return array ;}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];console.log(unique(arr))//[1, "a", "true", true, 15, false, 1, {…}, null, NaN, NaN, "NaN", 0, "a", {…}, undefined]

創建一個空Map數據結構,遍歷需要去重的數組,把數組的每一個元素作為key存到Map中。由于Map中不會出現相同的key值,所以最終得到的就是去重后的結果。

十一、利用reduce+includes

function unique(arr){  return arr.reduce((prev,cur) => prev.includes(cur) ? prev : [...prev,cur],[]);}var arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];console.log(unique(arr));// [1, "true", true, 15, false, undefined, null, NaN, "NaN", 0, "a", {…}, {…}]

十二、[...new Set(arr)]

[...new Set(arr)]//代碼就是這么少----(其實,嚴格來說并不算是一種,相對于第一種方法來說只是簡化了代碼)

PS:有些文章提到了foreach+indexOf數組去重的方法,個人覺得都是大同小異,所以沒有寫上去。

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運行工具http://tools.VeVB.COm/code/HtmlJsRun測試上述代碼運行效果。

PS:這里再為大家提供幾款相關工具供大家參考使用:

在線去除重復項工具:
http://tools.VeVB.COm/code/quchong

在線文本去重復工具:
http://tools.VeVB.COm/aideddesign/txt_quchong

更多關于JavaScript相關內容還可查看本站專題:《JavaScript數組操作技巧總結》、《JavaScript字符與字符串操作技巧總結》、《JavaScript遍歷算法與技巧總結》、《JavaScript查找算法技巧總結》、《JavaScript數學運算用法總結》、《JavaScript數據結構與算法技巧總結》及《JavaScript錯誤與調試技巧總結

希望本文所述對大家JavaScript程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 商南县| 大姚县| 灵石县| 涟水县| 莲花县| 宣汉县| 孟连| 寿阳县| 象山县| 东乡县| 惠来县| 汶上县| 上高县| 安溪县| 当阳市| 兴业县| 沂南县| 交口县| 玉环县| 和田市| 昌宁县| 阿拉善右旗| 宁安市| 常州市| 青龙| 汉源县| 山西省| 辽阳县| 旅游| 安新县| 博罗县| 府谷县| 宾川县| 云林县| 资兴市| 岳阳县| 门头沟区| 繁峙县| 西林县| 霸州市| 桑日县|