首頁 >web前端 >js教程 >apply和Math.max()使用與區別

apply和Math.max()使用與區別

php中世界最好的语言
php中世界最好的语言原創
2018-05-08 14:29:512173瀏覽

這次帶給大家apply和Math.max()使用與區別,apply和Math.max()使用與區別的注意事項有哪些,下面就是實戰案例,一起來看一下。

var arr=[1,3,6,3,7,9,2];
console.log(Math.max.apply(null,arr));

一直搞不懂為什麼這樣可以算出一個陣列的最大值?一直想不明白,請js高手指教一下。

答案1

Function.apply()是JS的一個OOP特性,一般用來模擬繼承和擴充this的用途,對於上面這段程式碼,可以這樣去理解:

XXX.apply是一個呼叫函數的方法,其參數為:apply(Function, Args),

Function為要呼叫的方法,Args是參數列表,當Function為null時,預設為上文,

Math.max.apply(null, arr)

可認為是

apply(Math.max, arr)

然後,arr是一個參數列表,對於max方法,其參數是若干個數,即

Math.max(a, b, c, d, ...)

當使用apply時,把所有參數加入到一個數組中,即

arr = [a, b, c, d, ...]

代入到原式,

Math.max.apply(null, [a, b, c, d, ...])

實際上等同於

Math.max(a, b, c, d, ...)

在此處,使用apply的優點是在部分JS引擎中提升效能。

答案2

Math.max()方法,支援傳遞多個參數,例如: Math.max(1,4,2,3,7,5,6)

但是它不支援直接傳遞一個陣列作為參數,例如:Math.max(new Array( 1,4,2,3,7,5,6))

這裡,只要我們有方法把數組,一個一個分開來,傳遞到Math.max()方法中,就實作了傳遞數組的方法。

所有函數都有apply(作用域鏈,參數)這個方法,這個函數的“參數”,接收一個數組,並且是將數組中的每個值,分開來,傳遞給調

補充:

Javascript中Math.max.apply與Math.max的差異

Javascript中的Math.max方法可以求出給定參數中最大的數。

> Math.max('1','2','3.1','3.2')
< 3.2
> Math.min(1,0,-1)
< -1

但如果是數組,就不能這樣呼叫了。

此時就用到了apply方法:

apply 方法 (Function) (JavaScript)
调用函数,并用指定对象替换函数的 this 值,同时用指定数组替换函数的参数。
apply([thisObj[,argArray]])
thisObj
  可选。 要用作 this 对象的对象。
argArray

  可選。要傳遞到函數的一組參數。
巧妙地讓陣列也可以呼叫Math.max和Math.min。

> Math.max.apply(null, ['1','2','3.1','3.2'])
< 3.2
> Math.min.apply(null, [1,0,-1])
< -1

我相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

EL取得上下文參數步驟詳解

#文字超過規定行數時增加省略號

以上是apply和Math.max()使用與區別的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn