摘要:前端學(xué)習(xí)教程開(kāi)發(fā)模塊化規(guī)范化工程化優(yōu)化工具調(diào)試值得關(guān)注的博客面試前端資源匯總歡迎提斧正數(shù)組去重?cái)?shù)組去重由慢到快由繁到簡(jiǎn)演化去重寫(xiě)法,箭頭函數(shù)為新寫(xiě)法。在去重過(guò)程中,原數(shù)組都是不變的。它類似于數(shù)組,但是成員的值都是唯一的,沒(méi)有重復(fù)的值。
前端學(xué)習(xí):教程&開(kāi)發(fā)模塊化/規(guī)范化/工程化/優(yōu)化&工具/調(diào)試&值得關(guān)注的博客/Git&面試-前端資源匯總
歡迎提issues斧正:數(shù)組去重
JavaScript-數(shù)組去重由慢到快由繁到簡(jiǎn)演化 indexOf去重Array.prototype.unique1 = function() { var arr = []; for (var i = 0; i < this.length; i++) { var item = this[i]; if (arr.indexOf(item) === -1) { arr.push(item); } } return arr; } [1,2,3,"4",3,4,3,1,"34",2].unique1(); //[1, 2, 3, "4", 4, "34"] //filter+indexOf寫(xiě)法,箭頭函數(shù)為ES6新寫(xiě)法。 Array.prototype.unique1 = function() { return this.filter((item, index, arr) => arr.indexOf(item) === index); }
indexOf的思想就是遍歷一個(gè)數(shù)組的字符,判斷這個(gè)字符在另一個(gè)數(shù)組存不存在,不存在就把這個(gè)字符也弄一個(gè)到結(jié)果數(shù)組里去。在 IE6-8 下,數(shù)組的 indexOf 方法還不存在(雖然這已經(jīng)算有點(diǎn)古老的話題了O(∩_∩)O~),但是,程序員就要寫(xiě)一個(gè)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; } Array.prototype.unique2 = function() { var arr = []; for (var i = 0; i < this.length; i++) { var item = this[i]; if (arr.indexOf(item) === -1) { arr.push(item); } } return arr; } [1,2,3,"4",3,4,3,1,"34",2].unique2(); //[1, 2, 3, "4", 4, "34"]
indexOf還可以以這樣的去重思路:判斷當(dāng)前字符在數(shù)組中出現(xiàn)的位置是不是第一次出現(xiàn)的位置,如果是就把字符放到結(jié)果數(shù)組中。在去重過(guò)程中,原數(shù)組都是不變的。
Array.prototype.unique3 = function(){ var arr = [this[0]]; for(var i = 1; i < this.length; i++){ if (this.indexOf(this[i]) == i){ arr.push(this[i]); } } return arr; } [1,2,3,"4",3,4,3,1,"34",2].unique3(); //[1, 2, 3, "4", 4, "34"]hash去重
以上indexOf正確性沒(méi)問(wèn)題,但性能上,兩重循環(huán)會(huì)降低性能。那我們就用hash。
Array.prototype.unique4 = function() { var arr = []; var hash = {}; for (var i = 0; i < this.length; i++) { var item = this[i]; var key = typeof(item) + item if (hash[key] !== 1) { arr.push(item); hash[key] = 1; } } return arr; } [1,2,3,"4",3,4,3,1,"34",2].unique4(); //[1, 2, 3, "4", 4, "34"]
hash去重的核心是構(gòu)建了一個(gè) hash 對(duì)象來(lái)替代 indexOf。以空間換時(shí)間。注意在 JavaScript 里,對(duì)象的鍵值只能是字符串,因此需要var key = typeof(item) + item 來(lái)區(qū)分?jǐn)?shù)值 1 和字符串 "1" 等情況。(當(dāng)然,ES6提供了Map數(shù)據(jù)結(jié)構(gòu)。它類似于對(duì)象,也是鍵值對(duì)的集合,但是“鍵”的范圍不限于字符串,各種類型的值(包括對(duì)象)都可以當(dāng)作鍵。也就是說(shuō),Object結(jié)構(gòu)提供了“字符串—值”的對(duì)應(yīng),Map結(jié)構(gòu)提供了“值—值”的對(duì)應(yīng),是一種更完善的Hash結(jié)構(gòu)現(xiàn)。)
那如果你想要"4" 和 4 被認(rèn)為是相同的話(其他方法同理)
Array.prototype.unique5 = function(){ var arr=[]; var hash={}; for(var i=0,len=this.length;i排序后去重 Array.prototype.unique6 = function(){ this.sort(); var arr = [this[0]]; for(var i = 1; i < this.length; i++){ if( this[i] !== arr[arr.length-1]){ arr.push(this[i]); } } return arr; } [1,2,3,"4",3,4,3,1,"34",2].unique6(); //[1, 2, 3, "34", "4", 4]先把數(shù)組排序,然后比較相鄰的兩個(gè)值,排序的時(shí)候用的JS原生的sort方法,所以非常快。而這個(gè)方法的缺陷只有一點(diǎn),比較字符時(shí)按照字符編碼的順序進(jìn)行排序。所以會(huì)看到10排在2前面這種情況。不過(guò)在去重中不影響。不過(guò),解決sort的這個(gè)問(wèn)題,是sort方法接受一個(gè)參數(shù),這個(gè)參數(shù)是一個(gè)方法:
function compare(value1,value2) { if (value1 < value2) { return -1; } else if (value1 > value2) { return 1; } else { return 0; } } [1,2,5,2,10,3,20].sort(compare); //[1, 2, 2, 3, 5, 10, 20]Set去重ES6提供了新的數(shù)據(jù)結(jié)構(gòu)Set。它類似于數(shù)組,但是成員的值都是唯一的,沒(méi)有重復(fù)的值。現(xiàn)在瀏覽器正在全面支持,服務(wù)端的node也已經(jīng)支持。
Array.prototype.unique7 = function(){ return [...new Set(this)]; } [1,2,3,"4",3,4,3,1,"34",2].unique7(); //[1, 2, 3, "4", 4, "34"]方法庫(kù)推薦一個(gè)方法庫(kù)Underscore.js,在node或?yàn)g覽器js中都很受歡迎。
const _ = require("underscore"); _.uniq([1, 2, 1, 3, 1, 4]); //[1, 2, 3, 4]測(cè)試時(shí)間以上方法均可以用一個(gè)簡(jiǎn)單的方法去測(cè)試一下所耗費(fèi)的時(shí)間,然后對(duì)各個(gè)方法做比較擇優(yōu):
console.time("test"); [1,2,3,"4",3,4,3,1,"34",2].unique7(); console.timeEnd("test"); ==> VM314:3 test: 0.378ms讓數(shù)據(jù)變得大一點(diǎn),就隨機(jī)創(chuàng)建100萬(wàn)個(gè)數(shù):
var arr = []; var num = 0; for(var i = 0; i < 1000000; i++){ num = Math.floor(Math.random()*100); arr.push(num); } console.time("test"); arr.unique7(); console.timeEnd("test"); ==> VM325:3 test: 108025.815ms (比較數(shù)目越多,差距越大,更好選擇)我們平時(shí)使用數(shù)組去重的地方,視業(yè)務(wù)不同,需求量不一樣。但使用的方法則可以視業(yè)務(wù)場(chǎng)景而選擇一個(gè)正確的合適的方法來(lái)寫(xiě)代碼。更重要的是我們的代碼要寫(xiě)來(lái)讓別人看得懂...寫(xiě)晦澀難懂的代碼切不做注釋只是裝得一手好逼。。。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/87878.html
摘要:規(guī)定動(dòng)畫(huà)完成一個(gè)周期所花費(fèi)的秒或毫秒。等同于貝塞爾曲線平滑過(guò)渡。等同于貝塞爾曲線由慢到快再到慢。等同于貝塞爾曲線等同于等同于接受兩個(gè)參數(shù)的步進(jìn)函數(shù)。特定的貝塞爾曲線類型,個(gè)數(shù)值需在區(qū)間內(nèi)規(guī)定動(dòng)畫(huà)何時(shí)開(kāi)始。 實(shí)現(xiàn)如圖所示的點(diǎn)點(diǎn)點(diǎn)loading效果:showImg(https://segmentfault.com/img/bVM22d?w=146&h=46); 一:CSS3 animati...
摘要:備注沒(méi)整理格式,抱歉動(dòng)畫(huà)實(shí)現(xiàn)的幾種方式性能排序?qū)崿F(xiàn)方式自身調(diào)用調(diào)用的定時(shí)器值推薦最小使用的原因即每秒幀為什么倒計(jì)時(shí)動(dòng)畫(huà)一定要用而避免使用兩者區(qū)別及引發(fā)的線程討論線程討論為什么單線程是的一大特性。 備注:沒(méi)整理格式,抱歉 動(dòng)畫(huà)實(shí)現(xiàn)的幾種方式:性能排序js < requestAnimationFrame 3->4->2. 那么在來(lái)看你這段代碼。 var t = true; window...
摘要:站點(diǎn)前端開(kāi)發(fā)文檔原文選擇器原文繼承屬性原文核心模塊原文盒子模型原文背景圖像原文清除浮動(dòng)原文定位選擇器并集對(duì)選擇器進(jìn)行分組,被分組的選擇器可以分享相同的聲明。用逗號(hào)將需要分組的選擇器開(kāi)分。 站點(diǎn):前端開(kāi)發(fā)文檔原文:CSS選擇器原文:CSS繼承屬性原文:CSS3核心模塊原文:CSS盒子模型原文:CSS背景圖像原文:CSS清除浮動(dòng)原文:CSS定位 CSS選擇器 并集:對(duì)選擇器進(jìn)行分組,...
摘要:創(chuàng)建數(shù)組數(shù)組字面量數(shù)組構(gòu)造函數(shù)參數(shù)為數(shù)組建議使用數(shù)組字面量方式,性能好,代碼少,簡(jiǎn)潔,畢竟代碼少。數(shù)組判斷方法用來(lái)判斷某個(gè)值是否為。的這是最簡(jiǎn)潔最直接的遍歷數(shù)組元素的語(yǔ)法。把數(shù)組轉(zhuǎn)換為本地?cái)?shù)組,并返回結(jié)果。 前端學(xué)習(xí):前端教程&開(kāi)發(fā)模塊化/規(guī)范化/工程化/優(yōu)化&工具/調(diào)試&值得關(guān)注的博客/Git&面試-前端資源匯總 歡迎提issues斧正:數(shù)組&數(shù)組方法使用詳解 Array對(duì)象 之前一...
閱讀 3529·2021-09-27 13:35
閱讀 3567·2019-08-29 17:09
閱讀 2438·2019-08-26 11:30
閱讀 709·2019-08-26 10:32
閱讀 540·2019-08-26 10:23
閱讀 1202·2019-08-26 10:20
閱讀 3159·2019-08-23 15:26
閱讀 3565·2019-08-23 14:33