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

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

 更新時(shí)間:2016年03月23日 11:22:41   作者:大漠  
在實(shí)際業(yè)務(wù)中有的時(shí)候要取出數(shù)組中的最大值或最小值。但在數(shù)組中并沒有提供arr.max()和arr.min()這樣的方法。那么是不是可以通過別的方式實(shí)現(xiàn)類似這樣的方法呢?那么今天我們就來整理取出數(shù)組中最大值和最小值的一些方法,需要的朋友一起學(xué)習(xí)吧

推薦閱讀:JavaScript學(xué)習(xí)筆記之?dāng)?shù)組的增、刪、改、查

JavaScript學(xué)習(xí)筆記之?dāng)?shù)組求和方法

JavaScript學(xué)習(xí)筆記之?dāng)?shù)組隨機(jī)排序

在實(shí)際業(yè)務(wù)中有的時(shí)候要取出數(shù)組中的最大值或最小值。但在數(shù)組中并沒有提供arr.max()和arr.min()這樣的方法。那么是不是可以通過別的方式實(shí)現(xiàn)類似這樣的方法呢?那么今天我們就來整理取出數(shù)組中最大值和最小值的一些方法。

取數(shù)組中最大值

可以先把思路理一下:

將數(shù)組中第一個(gè)元素賦值給一個(gè)變量,并且把這個(gè)變量作為最大值;

開始遍歷數(shù)組,從第二個(gè)元素開始依次和第一個(gè)元素進(jìn)行比較

如果當(dāng)前的元素大于當(dāng)前的最大值,就把當(dāng)前的元素值賦值給最大值

移動到下一個(gè)元素,繼續(xù)按前面一步操作

當(dāng)數(shù)組元素遍歷結(jié)束時(shí),這個(gè)變量存儲的就是最大值

代碼如下:

Array.prototype.max = function () {
// 將數(shù)組第一個(gè)元素的值賦給max
var max = this[0];
// 使用for 循環(huán)從數(shù)組第一個(gè)值開始做遍歷
for (var i = 1; i < this.length; i++) {
// 如果元素當(dāng)前值大于max,就把這個(gè)當(dāng)前值賦值給max
if (this[i] > max) {
max = this[i];
}
}
// 返回最大的值
return max;
}

來看一個(gè)示例:

var arr = [1,45,23,3,6,2,7,234,56];
arr.max(); // 234

上面的示例,數(shù)組中都是數(shù)值,那么如果數(shù)組中不全是數(shù)值會是一個(gè)什么樣的效果呢?來測試一下先:

var arr = [1,45,23,3,6,2,7,234,56,'2345','a','c'];
arr.max(); // 'c'

這并不是我們想要的結(jié)果吧。(此處跪求解決方案)

通過前段時(shí)間的學(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ù)組中最小值

類似取最大值的思路一樣,我們可以很輕松的實(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()方法可以接收一個(gè)回調(diào)函數(shù)callbackfn,可以在這個(gè)回調(diào)函數(shù)中拿數(shù)組中的初始值(preValue)與數(shù)組中當(dāng)前被處理的數(shù)組項(xiàng)(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

同樣的也可以使用類似的方法實(shí)現(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()方法。使用這兩個(gè)內(nèi)置函數(shù)可以分別找出數(shù)組中的最大值和最上值。在使用這兩種內(nèi)置函數(shù)取出數(shù)組最大和最小值之前,先學(xué)習(xí)一下Math.max()和Math.min()兩個(gè)函數(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。最主要的是這兩個(gè)函數(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對象也是一個(gè)對象,可以使用對象的字面量來寫,如:

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

其實(shí)還有更簡單的方法?;贓S2015的方法來實(shí)現(xiàn)此功能,是使用展開運(yùn)算符:

var numbers = [1, 2, 3, 4];
Math.max(...numbers) // 4
Math.min(...numbers) // 1

此運(yùn)算符使數(shù)組中的值在函數(shù)調(diào)用的位置展開。

總結(jié)

這篇文章整理了幾個(gè)從數(shù)組中取出最大值和最小值的方法。這幾個(gè)方法都只是會對于數(shù)字?jǐn)?shù)組,而對于數(shù)組中包含其他數(shù)據(jù)類型時(shí),如何只取出最大的數(shù)值和最小的數(shù)值(如果您知道如何實(shí)現(xiàn),還望指點(diǎn)迷津)。而這幾種方法當(dāng)中,使用JavaScript的內(nèi)置函數(shù)Math.max()和Math.min()配合Function.prototype.apply()可以輕松取出數(shù)組中的最大值和最小值。當(dāng)然最最簡單的要當(dāng)數(shù)ES2015中使用展示運(yùn)算符的方法。

關(guān)于JavaScript學(xué)習(xí)筆記之取數(shù)組中最大值和最小值的方法就給大家介紹這么多,如果大家還有更好的方案,希望能在下面的評論中與我們一起分享。

相關(guān)文章

  • js有序數(shù)組的連接問題

    js有序數(shù)組的連接問題

    昨天碰到一道關(guān)于如何解決有序數(shù)組的連接問題,這是一個(gè)很常見的問題。但是這里要考慮到代碼的效率問題,因?yàn)橐B接的數(shù)組都是有序的,這是一個(gè)非常重要的前提條件
    2013-10-10
  • js模擬C#中List的簡單實(shí)例

    js模擬C#中List的簡單實(shí)例

    本篇文章主要是對js模擬C#中List的簡單實(shí)例進(jìn)行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2014-03-03
  • javascript實(shí)現(xiàn)動態(tài)增加刪除表格行(兼容IE/FF)

    javascript實(shí)現(xiàn)動態(tài)增加刪除表格行(兼容IE/FF)

    javascript實(shí)現(xiàn)動態(tài)增加刪除表格行(兼容IE/FF)...
    2007-04-04
  • JS中利用swiper實(shí)現(xiàn)3d翻轉(zhuǎn)幻燈片實(shí)例代碼

    JS中利用swiper實(shí)現(xiàn)3d翻轉(zhuǎn)幻燈片實(shí)例代碼

    大家都知道Swiper(Swiper master)是目前應(yīng)用較廣泛的移動端網(wǎng)頁觸摸內(nèi)容滑動js插件。下面這篇文章主要給大家介紹了在JS中利用swiper實(shí)現(xiàn)3d翻轉(zhuǎn)幻燈片的相關(guān)資料,文中給出了完整的示例代碼供大家參考學(xué)習(xí),需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-08-08
  • JavaScript查看代碼運(yùn)行效率console.time()與console.timeEnd()用法

    JavaScript查看代碼運(yùn)行效率console.time()與console.timeEnd()用法

    今天小編就為大家分享一篇關(guān)于JavaScript查看代碼運(yùn)行效率console.time()與console.timeEnd()用法,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • Bootstrap菜單按鈕及導(dǎo)航實(shí)例解析

    Bootstrap菜單按鈕及導(dǎo)航實(shí)例解析

    這篇文章主要介紹了Bootstrap菜單按鈕及導(dǎo)航的相關(guān)資料,本文介紹的非常詳細(xì),具有參考借鑒價(jià)值,感興趣的朋友一起學(xué)習(xí)吧
    2016-09-09
  • JavaScript常用方法和封裝詳情

    JavaScript常用方法和封裝詳情

    這篇文章主要介紹了JavaScript常用方法和封裝詳情,文章圍繞JavaScript的方法和封裝相關(guān)資料展開詳情,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-03-03
  • js如何編寫簡單的ajax方法庫

    js如何編寫簡單的ajax方法庫

    這篇文章主要為大家詳細(xì)介紹了js如何編寫簡單的ajax方法庫,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • 很棒的一組js圖片輪播特效

    很棒的一組js圖片輪播特效

    這篇文章主要為大家分享了一款很棒的js組輪播特效,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • JavaScript常用數(shù)組元素搜索或過濾的四種方法詳解

    JavaScript常用數(shù)組元素搜索或過濾的四種方法詳解

    這篇文章主要介紹了JavaScript常用數(shù)組元素搜索或過濾的四種方法,每種方式通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-08-08

最新評論