js中apply和Math.max()函数介绍

小云云
Freigeben: 2018-03-28 09:05:49
Original
1993 Leute haben es durchsucht

本文主要和大家介绍了js中apply和Math.max()函数的问题,在文章底部给大家提到了js中Math.max.apply和Math.max的区别,希望能帮助到大家。

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

一直搞不懂为什么这样可以算出一个数组的最大值?一直想不明白,请js高手指教一下。

答案1

Function.apply()是JS的一个OOP特性,一般用来模拟继承和扩展this的用途,对于上面这段代码,可以这样去理解:

XXX.apply是一个调用函数的方法,其参数为:apply(Function, Args),

Function为要调用的方法,Args是参数列表,当Function为null时,默认为上文,

Math.max.apply(null, arr)
Nach dem Login kopieren

可认为是

apply(Math.max, arr)
Nach dem Login kopieren

然后,arr是一个参数列表,对于max方法,其参数是若干个数,即

Math.max(a, b, c, d, ...)
Nach dem Login kopieren
Nach dem Login kopieren

当使用apply时,把所有参数加入到一个数组中,即

arr = [a, b, c, d, ...]
Nach dem Login kopieren

代入到原式,

Math.max.apply(null, [a, b, c, d, ...])
Nach dem Login kopieren

实际上等同于

Math.max(a, b, c, d, ...)
Nach dem Login kopieren
Nach dem Login kopieren

在此处,使用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
Nach dem Login kopieren

但如果是数组,就不能这样调用了。

此时就用到了apply方法:

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

  可选。 要传递到函数的一组参数。
巧妙地使数组也可以调用Math.max和Math.min。

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

相关推荐:

JavaScript之call和apply

Das obige ist der detaillierte Inhalt vonjs中apply和Math.max()函数介绍. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!