欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript數(shù)組去重由慢到快由繁到簡(優(yōu)化篇)

 更新時間:2016年08月26日 08:52:00   作者:人在路途  
本文給大家介紹通過indexof去重,hash去重,排序后去重及set去重由慢到快有繁到簡的方法給大家介紹了js數(shù)組去重的方法,非常不錯,具有參考借鑒價值,感興趣的朋友一起看看吧

在進(jìn)行數(shù)組操作時往往會遇到去掉重復(fù)項的問題,下面簡單介紹下數(shù)組去重的方法。

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"]

不過,在 IE6-8 下,數(shù)組的 indexOf 方法還不存在(雖然這已經(jīng)算有點古老的話題了O(∩_∩)O~),但是,程序員就要寫一個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還可以以這樣的去重思路:

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正確性沒問題,但性能上,兩重循環(huán)會降低性能。那我們就用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"]

核心是構(gòu)建了一個 hash 對象來替代 indexOf??臻g換時間。注意在 JavaScript 里,對象的鍵值只能是字符串(當(dāng)然,ES6提供了Map數(shù)據(jù)結(jié)構(gòu)。它類似于對象,也是鍵值對的集合,但是“鍵”的范圍不限于字符串,各種類型的值(包括對象)都可以當(dāng)作鍵。也就是說,Object結(jié)構(gòu)提供了“字符串—值”的對應(yīng),Map結(jié)構(gòu)提供了“值—值”的對應(yīng),是一種更完善的Hash結(jié)構(gòu)現(xiàn)。),因此需要var key = typeof(item) + item 來區(qū)分?jǐn)?shù)值 1 和字符串 '1' 等情況。

那如果你想要'4' 和 4 被認(rèn)為是相同的話(其他方法同理)

Array.prototype.unique5 = function(){
var arr=[];
var hash={};
for(var i=0,len=this.length;i<len;i++){
if(!hash[this[i]]){ 
arr.push(this[i]);
hash[this[i]]=true;
}
}
return arr;
}
[1,2,3,'4',3,4,3,1,'34',2].unique5(); //[1, 2, 3, "4", "34"]

排序后去重

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ù)組排序,然后比較相鄰的兩個值,排序的時候用的JS原生的sort方法,所以非??臁6@個方法的缺陷只有一點,比較字符時按照字符編碼的順序進(jìn)行排序。所以會看到10排在2前面這種情況。不過在去重中不影響。不過,解決sort的這個問題,是sort方法接受一個參數(shù),這個參數(shù)是一個方法:

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ù)組,但是成員的值都是唯一的,沒有重復(fù)的值?,F(xiàn)在瀏覽器正在全面支持,服務(wù)端的node也已經(jīng)支持。

Array.prototype.unique7 = function(){
return Array.from(new Set(this));
}
[1,2,3,'4',3,4,3,1,'34',2].unique7(); //[1, 2, 3, "4", 4, "34"]

方法庫

推薦一個方法庫Underscore.js,在node或瀏覽器js中都很受歡迎。

const _ = require('underscore');
_.uniq([1, 2, 1, 3, 1, 4]); //[1, 2, 3, 4]

測試時間

以上方法均可以用一個簡單的方法去測試一下所耗費(fèi)的時間,然后對各個方法做比較擇優(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ù)變得大一點,就隨機(jī)創(chuàng)建100萬個數(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");

以上所述是小編給大家介紹的JavaScript數(shù)組去重由慢到快由繁到簡,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • js實現(xiàn)簡單選項卡制作

    js實現(xiàn)簡單選項卡制作

    這篇文章主要為大家詳細(xì)介紹了js實現(xiàn)簡單選項卡制作,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • Promise對象all與race方法手寫示例

    Promise對象all與race方法手寫示例

    這篇文章主要為大家介紹了Promise對象all與race方法手寫示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • 5種JavaScript腳本加載的方式

    5種JavaScript腳本加載的方式

    這篇文章主要為大家詳細(xì)介紹了5種JavaScript腳本加載的方式,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • js點擊圖片實現(xiàn)查看大圖簡單方法

    js點擊圖片實現(xiàn)查看大圖簡單方法

    今天開發(fā)的時候,遇到要點擊縮略圖之后顯示圖片的大圖查看,所以本文給大家分享下,這篇文章主要給大家介紹了關(guān)于js點擊圖片實現(xiàn)查看大圖的簡單方法,需要的朋友可以參考下
    2023-06-06
  • JavaScript undefined及null區(qū)別實例解析

    JavaScript undefined及null區(qū)別實例解析

    這篇文章主要介紹了JavaScript undefined及null區(qū)別實例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-07-07
  • BootStrap 獲得輪播中的索引和當(dāng)前活動的焦點對象

    BootStrap 獲得輪播中的索引和當(dāng)前活動的焦點對象

    這篇文章主要介紹了BootStrap 獲得輪播中的索引和當(dāng)前活動的焦點對象,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2017-05-05
  • JavaScript 加號(+)運(yùn)算符號

    JavaScript 加號(+)運(yùn)算符號

    在一些框架中看到了類似這樣的寫法:+new Date();感覺有些怪,查閱了相關(guān)資料和一些網(wǎng)友的幫助.對此用法解釋如下,希望對大家有所幫助,不合適的地方請大家指正!
    2009-12-12
  • js閉包實現(xiàn)按秒計數(shù)

    js閉包實現(xiàn)按秒計數(shù)

    閉包是一個擁有許多變量和綁定了這些變量的環(huán)境的表達(dá)式(通常是一個函數(shù)),因而這些變量也是該表達(dá)式的一部分。相信很少有人能直接看懂這句話,因為他描述的太學(xué)術(shù)。其實這句話通俗的來說就是:JavaScript中所有的function都是一個閉包。
    2015-04-04
  • JS填寫銀行卡號每隔4位數(shù)字加一個空格

    JS填寫銀行卡號每隔4位數(shù)字加一個空格

    這篇文章主要介紹了JS填寫銀行卡號每隔4位數(shù)字加一個空格的相關(guān)資料,需要的朋友可以參考下
    2016-12-12
  • 淺談JS的原型和繼承

    淺談JS的原型和繼承

    這篇文章主要介紹了JS原型和繼承,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05

最新評論