JavaScript學(xué)習(xí)筆記之取數(shù)組中最大值和最小值

字號:


    在實際業(yè)務(wù)中有的時候要取出數(shù)組中的最大值或最小值。但在數(shù)組中并沒有提供arr.max()和arr.min()這樣的方法。那么是不是可以通過別的方式實現(xiàn)類似這樣的方法呢?那么今天我們就來整理取出數(shù)組中最大值和最小值的一些方法。
    取數(shù)組中最大值
    可以先把思路理一下:
    將數(shù)組中第一個元素賦值給一個變量,并且把這個變量作為最大值;
    開始遍歷數(shù)組,從第二個元素開始依次和第一個元素進(jìn)行比較
    如果當(dāng)前的元素大于當(dāng)前的最大值,就把當(dāng)前的元素值賦值給最大值
    移動到下一個元素,繼續(xù)按前面一步操作
    當(dāng)數(shù)組元素遍歷結(jié)束時,這個變量存儲的就是最大值
    代碼如下:
    Array.prototype.max = function () {
    // 將數(shù)組第一個元素的值賦給max
    var max = this[0];
    // 使用for 循環(huán)從數(shù)組第一個值開始做遍歷
    for (var i = 1; i < this.length; i++) {
    // 如果元素當(dāng)前值大于max,就把這個當(dāng)前值賦值給max
    if (this[i] > max) {
    max = this[i];
    }
    }
    // 返回最大的值
    return max;
    }
    來看一個示例:
    var arr = [1,45,23,3,6,2,7,234,56];
    arr.max(); // 234
    上面的示例,數(shù)組中都是數(shù)值,那么如果數(shù)組中不全是數(shù)值會是一個什么樣的效果呢?來測試一下先:
    var arr = [1,45,23,3,6,2,7,234,56,'2345','a','c'];
    arr.max(); // 'c'
    這并不是我們想要的結(jié)果吧。(此處跪求解決方案)
    通過前段時間的學(xué)習(xí),都知道for循環(huán)性能要比forEach()差,那可以將上面的方法改成forEach()方法:
    Array.prototype.max = function (){
    var max = this[0];
    this.forEach (function(ele,index,arr){
    if(ele > max) {
    max = ele;
    }
    })
    return max;
    }
    var arr = [1,45,23,3,6,2,7,234,56];
    arr.max(); // 234
    取數(shù)組中最小值
    類似取最大值的思路一樣,我們可以很輕松的實現(xiàn)arr.min()方法,取出數(shù)組中的最小值:
    Array.prototype.min = function () {
    var min = this[0];
    this.forEach(function(ele, index,arr) {
    if(ele < min) {
    min = ele;
    }
    })
    return min;
    }
    var arr = [1,45,23,3,6,2,7,234,56];
    arr.min(); // 1
    其他方法
    除了上面的方案,還可以有其他方法,比如使用數(shù)組的reduce()方法?;貞浨懊娴膶W(xué)過的知識,reduce()方法可以接收一個回調(diào)函數(shù)callbackfn,可以在這個回調(diào)函數(shù)中拿數(shù)組中的初始值(preValue)與數(shù)組中當(dāng)前被處理的數(shù)組項(curValue)做比較,如果preValue大于curValue值返回preValue,反之返回curValue值,依此類推取出數(shù)組中最大值:
    Array.prototype.max = function() {
    return this.reduce(function(preValue, curValue,index,array) {
    return preValue > curValue ? preValue : curValue;
    })
    }
    var arr = [1,45,23,3,6,2,7,234,56];
    arr.max(); // 234
    同樣的也可以使用類似的方法實現(xiàn)arr.mix()方法,取出數(shù)組中的最小值:
    Array.prototype.min = function() {
    return this.reduce(function(preValue, curValue,index,array) {
    return preValue > curValue ? curValue : preValue;
    })
    }
    var arr = [1,45,23,3,6,2,7,234,56];
    arr.min(); // 1
    內(nèi)置函數(shù)Math.max()和Math.min()方法
    對于純數(shù)字?jǐn)?shù)組,可以使用JavaScript中的內(nèi)置函數(shù)Math.max()和Math.min()方法。使用這兩個內(nèi)置函數(shù)可以分別找出數(shù)組中的最大值和最上值。在使用這兩種內(nèi)置函數(shù)取出數(shù)組最大和最小值之前,先學(xué)習(xí)一下Math.max()和Math.min()兩個函數(shù)。
    Math.max()
    Math.max()函數(shù)返回一組數(shù)中的最大值。
    Math.max(1,32,45,31,3442,4); // 3442
    Math.max(10, 20); // 20
    Math.max(-10, -20); // -10
    Math.max(-10, 20); // 20
    Math.min()
    Math.min()函數(shù)和Math.max()函數(shù)剛好相反,其會返回一組數(shù)中的最小值:
    Math.min(10,20); //10
    Math.min(-10,-20); //-20
    Math.min(-10,20); //-10
    Math.min(1,32,45,31,3442,4); //1
    這些函數(shù)如果沒有參數(shù),則結(jié)果為 -Infinity;如果有任一參數(shù)不能被轉(zhuǎn)換為數(shù)值,則結(jié)果為 NaN。最主要的是這兩個函數(shù)對于數(shù)字組成的數(shù)組是不能直接使用的。但是,這有一些類似地方法。
    Function.prototype.apply()讓你可以使用提供的this與參數(shù)組與的數(shù)組來調(diào)用參數(shù)。
    // 取出數(shù)組中最大值
    Array.max = function( array ){
    return Math.max.apply( Math, array );
    };
    // 取出數(shù)組中最小值
    Array.min = function( array ){
    return Math.min.apply( Math, array );
    };
    var arr = [1,45,23,3,6,2,7,234,56];
    Array.max(arr); // 234
    Array.min(arr); // 1
    Math對象也是一個對象,可以使用對象的字面量來寫,如:
    Array.prototype.max = function () {
    return Math.max.apply({},this);
    }
    Array.prototype.min = function () {
    return Math.min.apply({},this);
    }
    var arr = [1,45,23,3,6,2,7,234,56];
    arr.max(); // 234
    arr.min(); // 1
    其實還有更簡單的方法?;贓S2015的方法來實現(xiàn)此功能,是使用展開運算符:
    var numbers = [1, 2, 3, 4];
    Math.max(...numbers) // 4
    Math.min(...numbers) // 1
    此運算符使數(shù)組中的值在函數(shù)調(diào)用的位置展開。
    總結(jié)
    這篇文章整理了幾個從數(shù)組中取出最大值和最小值的方法。這幾個方法都只是會對于數(shù)字?jǐn)?shù)組,而對于數(shù)組中包含其他數(shù)據(jù)類型時,如何只取出最大的數(shù)值和最小的數(shù)值(如果您知道如何實現(xiàn),還望指點迷津)。而這幾種方法當(dāng)中,使用JavaScript的內(nèi)置函數(shù)Math.max()和Math.min()配合Function.prototype.apply()可以輕松取出數(shù)組中的最大值和最小值。當(dāng)然最最簡單的要當(dāng)數(shù)ES2015中使用展示運算符的方法。
    關(guān)于JavaScript學(xué)習(xí)筆記之取數(shù)組中最大值和最小值的方法就給大家介紹這么多,如果大家還有更好的方案,希望能在下面的評論中與我們一起分享。