摘要:基本操作數(shù)組去重寫在前面數(shù)組去重經(jīng)常出現(xiàn)在前端招聘的筆試題里,比如有數(shù)組,請用實現(xiàn)去重函數(shù),使得返回作為筆試題,考點有二正確。基本介紹文章主要是對數(shù)組去重的常用方法進(jìn)行介紹。
js基本操作-數(shù)組去重 寫在前面
JavaScript 數(shù)組去重經(jīng)常出現(xiàn)在前端招聘的筆試題里,比如:
有數(shù)組 var arr = ["a", "b", "c", "1", 0, "c", 1, "", 1, 0],請用 JavaScript 實現(xiàn)去重函數(shù) unqiue,使得 unique(arr) 返回 ["a", "b", "c", "1", 0, 1, ""]
作為筆試題,考點有二:
正確。別小看這個考點,考慮到 JavaScript 經(jīng)常要在瀏覽器上運(yùn)行,在千姿百態(tài)的各種瀏覽器環(huán)境下要保障一個函數(shù)的正確性可不是一件簡單的事,不信你繼續(xù)讀完這篇博客。
性能。雖然大部分情況下JavaScript語言本身(狹義范疇,不包含DOM等延拓)不會導(dǎo)致性能問題,但很不幸這是一道考題,因此面試官們還是會把性能作為一個考點。
所有的方法都來自網(wǎng)上,學(xué)到了才是自己的??!
然后,寫在前面,帶上我們可愛的小伙伴。
文章主要是對js數(shù)組去重的常用方法進(jìn)行介紹。JS去重,看起來簡單,但是其實暗藏許多的小竅門??嫉牟粌H僅是實現(xiàn)這個功能,更能看出你對計算機(jī)程序執(zhí)行的深入理解。下面將從數(shù)組去重的方法進(jìn)行詳細(xì)的了解。
數(shù)組去重的方法 1.嵌套循環(huán)比較兩層for循環(huán),for循環(huán)中每次從原數(shù)組中取出一個元素,用這個元素循環(huán)與結(jié)果數(shù)組對比。若結(jié)果數(shù)組中沒有該元素,則存到結(jié)果數(shù)組中。
Array.prototype.unique_towFor = Array.prototype.unique_towFor || function(){ var result = []; if(this.length <= 0) return result; result.push(this[0]); for(var i = 1; i < this.length; i++){ var notIn = true; for(var j = 0; j < result.length; j++){ if(this[i] == result[j]){ notIn = false; break; } } if(notIn){ result.push(this[i]); } } return result; }2.臨時數(shù)組保存
算法的基本思想,就是,把去重后的結(jié)果放在一個臨時數(shù)組中,對原來數(shù)組的元素與臨時數(shù)組元素比較,臨時數(shù)組中不存在這個元素的,放入臨時數(shù)組。
Array.prototype.unique_tempArray = Array.prototype.unique_tempArray || function(){ var result = [];//臨時數(shù)組 for(var i = 0; i < this.length; i++){ if(result.indexOf(this[i]) == -1){ result.push(this[i]); } } return result; }3.利用對象去重(基礎(chǔ)常用)
創(chuàng)建一個新的數(shù)組存放結(jié)果,和一個空對象。for循環(huán)時,每次取出一個元素與對象進(jìn)行對比,如果這個元素不重復(fù),則把它存放到結(jié)果數(shù)組中,同時把這個元素的內(nèi)容作為對象的一個屬性,并賦值,存入到對象中。這個方法用作統(tǒng)計也很方便。
Array.prototype.unique_objectArray = Array.prototype.unique_objectArray || function(){ var result = []; var obj = {}; for(var i = 0; i < this.length; i++){ if(!obj[this[i]]){ obj[this[i]] = 1; result.push(this[i]); }else{ obj[this[i]] ++; } } return result; }4.先排序,后去重
先把數(shù)組排序,然后比較相鄰的兩個值。 排序的時候用的JS原生的sort方法,JS引擎內(nèi)部用的是快速排序,此方法速度比較快!無語中。
Array.prototype.unique_sortArray = Array.prototype.unique_sortArray || function(){ this.sort(); var result = [this[0]]; for(var i = 1; i < this.length; i++){ if(this[i] !== result[result.length - 1] ){ result.push(this[i]); } } return result; }5.利用ES6的Set對象和Array.from方法
[ ] Set對象可以是任何類型的單個值的集合。它是ES6新增的有序列表集合,它不會包含重復(fù)項。之前我們通常用對象(Object)或者數(shù)組(Array)來實現(xiàn)沒有重復(fù)項的集合。
[ ] Array.from()方法可以將一個類數(shù)組對象或可遍歷對象轉(zhuǎn)換成真正的數(shù)組。
Array.prototype.unique_es6SetArray = Array.prototype.unique_esSetArray || function(){ return Array.from(new Set(this)); }6.利用filter和Map對象
[ ] filter()方法使用指定的函數(shù)測試所有元素,并創(chuàng)建一個包含所有通過測試的元素的新數(shù)組。
Array.prototype.unique_filterArray = Array.prototype.unique_filterArray || function(){ return this.filter(function(item, index, arr){ return arr.indexOf(item) === index; }); }
既然可以使用filter的方法,那么也可以使用filter加object的方法,這里使用Map對象。
Array.prototype.unique_es6MapArray = Array.prototype.unique_es6MapArray || function(){ const seen = new Map(); return this.filter(function(item, index, arr){ !seen.has(item) && seen.set(item, 1); }); }
這里的filter函數(shù)可以簡化,當(dāng)然也有人這樣寫
Array.prototype.unique_es6MapArray = Array.prototype.unique_es6MapArray || function(){ const seen = new Map(); return this.filter( (a) => !seen.has(a) && seen.set(a, 1) ); }7.使用第三方
最后,可以使用第三方庫函數(shù)jquery和underscore或者lodash
下面以lodash和underscore為例
Array.prototype.unique_3partyArray = Array.prototype.unique_3partyArray || function(){ return _.uniq(arr);//要先引入lodash.js或者underscore.js }其他說明
以上的所有方法,都來自網(wǎng)上。
所有的方法,都必須腳踏實地,在具體應(yīng)用場景下去分析、去選擇,我們應(yīng)該按照具體的情況,來選擇方法。
因為瀏覽器的多樣性,前端的應(yīng)用場景經(jīng)常很復(fù)雜,性能優(yōu)化充滿挑戰(zhàn),也充滿機(jī)遇。
學(xué)會了才是自己的,知道會用會寫,才是我們最終的目標(biāo)。
方法中,建議參考underscore.js的源代碼的方法。以下是underscore.js中uniq的源碼。
// Produce a duplicate-free version of the array. If the array has already // been sorted, you have the option of using a faster algorithm. // Aliased as `unique`. _.uniq = _.unique = function(array, isSorted, iteratee, context) { if (!_.isBoolean(isSorted)) { context = iteratee; iteratee = isSorted; isSorted = false; } if (iteratee != null) iteratee = cb(iteratee, context); var result = []; var seen = []; for (var i = 0, length = getLength(array); i < length; i++) { var value = array[i], computed = iteratee ? iteratee(value, i, array) : value; if (isSorted) { if (!i || seen !== computed) result.push(value); seen = computed; } else if (iteratee) { if (!_.contains(seen, computed)) { seen.push(computed); result.push(value); } } else if (!_.contains(result, value)) { result.push(value); } } return result; };
文檔說明如下:
uniq_.uniq(array, [isSorted], [iteratee]) Alias: unique
Produces a duplicate-free version of the array, using === to test object equality. In particular only the first occurence of each value is kept. If you know in advance that the array is sorted, passing true for isSorted will run a much faster algorithm. If you want to compute unique items based on a transformation, pass an iteratee function.
_.uniq([1, 2, 1, 4, 1, 3]);
=> [1, 2, 4, 3]
本文僅只用于學(xué)習(xí)、研究和交流目的,我也是學(xué)習(xí)過后慢慢總結(jié)過來的,如果有什么錯誤或者好的建議,歡迎大家批評指正!
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/91669.html
摘要:基本操作數(shù)組去重數(shù)組去重的方法臨時數(shù)組保存其實這里面還沒考慮到數(shù)組里面嵌套數(shù)組對象的情況把去重后的結(jié)果放在一個臨時數(shù)組中對原來數(shù)組的元素與臨時數(shù)組元素比較臨時數(shù)組中不存在這個元素的放入臨時數(shù)組。 js基本操作-數(shù)組去重 數(shù)組去重的方法 1. 臨時數(shù)組保存(其實這里面還沒考慮到數(shù)組里面嵌套數(shù)組/對象的情況) 把去重后的結(jié)果放在一個臨時數(shù)組中, 對原來數(shù)組的元素與臨時數(shù)組元素比較, 臨時...
摘要:數(shù)組去重看了網(wǎng)上很多數(shù)組去重方法,用的比較常見的大概就幾種,今天想自己來做一個總結(jié)。還有就是方法返回的數(shù)組也是排序后的數(shù)組,某些情況下可能不符合要求。 JS數(shù)組去重 看了網(wǎng)上很多數(shù)組去重方法,用的比較常見的大概就幾種,今天想自己來做一個總結(jié)。部分內(nèi)容參考該博客 1 . 在原數(shù)組上操作(基本方法) 思路:利用循環(huán)嵌套,判斷數(shù)組中每個元素與其后面的元素是否相等,如果相等,就使用spli...
最近lz一周排了9個面試,面試經(jīng)常被問到一些數(shù)組的問題,比如說es6里面一些數(shù)組去重、合并數(shù)組,之前壓根就沒了解過,后來才知道考的都是es6的知識,今天好好挖掘一下,發(fā)現(xiàn)一個神奇的點點三姐妹 我們來看看經(jīng)常使用的方法 1、數(shù)組去重 之前的想法可能要遍歷數(shù)組去重,但是現(xiàn)在又es6的騷操作 var a = [1,1,2,3] Array.from(new Set()) // 利用es6...
摘要:實現(xiàn)數(shù)組更多的高階函數(shù)吾輩的博客原文場景雖說人人平等,但有些人更加平等。若是有一篇適合萌新閱讀的自己實現(xiàn)數(shù)組更多操作的文章,情況或許會發(fā)生一些變化。類似于的初始值,但它是一個函數(shù),避免初始值在所有分組中進(jìn)行累加。 JavaScript 實現(xiàn)數(shù)組更多的高階函數(shù) 吾輩的博客原文: https://blog.rxliuli.com/p/fc... 場景 雖說人人平等,但有些人更加平等。 為...
數(shù)組去重的方式有很多種,現(xiàn)總結(jié)一些備以后查漏補(bǔ)缺來用。 對基本數(shù)組類型去重: (1)set 和 array.from()實現(xiàn) var str, strs = [a, b, c, er, d, er, a, b, c]; function removeRepeat(arr) { return Array.from(new Set(arr)) } console.log(remove...
閱讀 3947·2021-11-16 11:44
閱讀 3128·2021-11-12 10:36
閱讀 3383·2021-10-08 10:04
閱讀 1270·2021-09-03 10:29
閱讀 409·2019-08-30 13:50
閱讀 2623·2019-08-29 17:14
閱讀 1745·2019-08-29 15:32
閱讀 1090·2019-08-29 11:27