成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

js基本操作-數(shù)組去重

blastz / 3488人閱讀

摘要:基本操作數(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

相關(guān)文章

  • js基本操作-數(shù)組去重

    摘要:基本操作數(shù)組去重數(shù)組去重的方法臨時數(shù)組保存其實這里面還沒考慮到數(shù)組里面嵌套數(shù)組對象的情況把去重后的結(jié)果放在一個臨時數(shù)組中對原來數(shù)組的元素與臨時數(shù)組元素比較臨時數(shù)組中不存在這個元素的放入臨時數(shù)組。 js基本操作-數(shù)組去重 數(shù)組去重的方法 1. 臨時數(shù)組保存(其實這里面還沒考慮到數(shù)組里面嵌套數(shù)組/對象的情況) 把去重后的結(jié)果放在一個臨時數(shù)組中, 對原來數(shù)組的元素與臨時數(shù)組元素比較, 臨時...

    GeekGhc 評論0 收藏0
  • JS數(shù)組去重方法小結(jié)

    摘要:數(shù)組去重看了網(wǎng)上很多數(shù)組去重方法,用的比較常見的大概就幾種,今天想自己來做一個總結(jié)。還有就是方法返回的數(shù)組也是排序后的數(shù)組,某些情況下可能不符合要求。 JS數(shù)組去重 看了網(wǎng)上很多數(shù)組去重方法,用的比較常見的大概就幾種,今天想自己來做一個總結(jié)。部分內(nèi)容參考該博客 1 . 在原數(shù)組上操作(基本方法) 思路:利用循環(huán)嵌套,判斷數(shù)組中每個元素與其后面的元素是否相等,如果相等,就使用spli...

    PascalXie 評論0 收藏0
  • js擴(kuò)展運(yùn)算符,神奇的3個點點,數(shù)組去重、合并數(shù)組等等

    最近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...

    waltr 評論0 收藏0
  • JavaScript 實現(xiàn)數(shù)組更多的高階函數(shù)

    摘要:實現(xiàn)數(shù)組更多的高階函數(shù)吾輩的博客原文場景雖說人人平等,但有些人更加平等。若是有一篇適合萌新閱讀的自己實現(xiàn)數(shù)組更多操作的文章,情況或許會發(fā)生一些變化。類似于的初始值,但它是一個函數(shù),避免初始值在所有分組中進(jìn)行累加。 JavaScript 實現(xiàn)數(shù)組更多的高階函數(shù) 吾輩的博客原文: https://blog.rxliuli.com/p/fc... 場景 雖說人人平等,但有些人更加平等。 為...

    aervon 評論0 收藏0
  • js數(shù)組去重

    數(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...

    cartoon 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<