Heim > Web-Frontend > js-Tutorial > Einführung in die Funktionen apply und Math.max() in js

Einführung in die Funktionen apply und Math.max() in js

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

Dieser Artikel stellt Ihnen hauptsächlich die Probleme der Funktionen apply und Math.max() in js vor. Am Ende des Artikels habe ich den Unterschied zwischen Math.max.apply und Math.max in js erwähnt kann dir helfen.

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

Ich verstehe immer noch nicht, warum damit der Maximalwert eines Arrays berechnet werden kann? Ich kann es immer noch nicht herausfinden. Bitte geben Sie mir einen Rat von einem JS-Experten.

Antwort 1

Function.apply() ist eine OOP-Funktion von JS. Sie wird im Allgemeinen verwendet, um die Vererbung zu simulieren und die Verwendung von zu erweitern Dies. Der obige Code kann wie folgt verstanden werden:

XXX.apply ist eine Methode zum Aufrufen einer Funktion und ihre Parameter sind: apply(Function, Args),

Function ist die Die aufzurufende Methode Args ist die Parameterliste. Wenn die Funktion null ist, wird standardmäßig das obige verwendet, d. h.

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

apply(Math.max, arr)
Nach dem Login kopieren
betrachtet werden Dann ist arr eine Parameterliste. Für die Max-Methode sind ihre Parameter mehrere Zahlen, d. h.

Math.max(a, b, c, d, ...)
Nach dem Login kopieren
Nach dem Login kopieren
. Wenn Sie apply verwenden, fügen Sie alle Parameter zu einem Array hinzu, d

wird in die ursprüngliche Formel eingesetzt,

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

entspricht tatsächlich

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

Hier besteht der Vorteil der Verwendung von apply darin, die Leistung in einigen JS-Engines zu verbessern.

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

Antwort 2

Methode unterstützt die Übergabe mehrerer Parameter, wie zum Beispiel:

Math.max()Aber direkt Die Übergabe eines Arrays als Parameter wird nicht unterstützt, z. B.: Math.max(1,4,2,3,7,5,6).

Solange wir eine Möglichkeit haben, das Array einzeln aufzuteilen und an die Math.max()-Methode zu übergeben, ist die Methode zur Übergabe des Arrays implementiert. Math.max(new Array(1,4,2,3,7,5,6))

Alle Funktionen verfügen über die Apply-Methode (Bereichskette, Parameter). Der „Parameter“ dieser Funktion empfängt ein Array, trennt jeden Wert im Array und übergibt ihn an den Aufrufer

Ergänzung:

Der Unterschied zwischen Math.max.apply und Math.max in Javascript

Javascript Der Math.max Methode in kann die größte Zahl unter den angegebenen Parametern finden.

Wenn es sich jedoch um ein Array handelt, kann es nicht so aufgerufen werden.

> Math.max('1','2','3.1','3.2')
< 3.2
> Math.min(1,0,-1)
< -1
Nach dem Login kopieren
Zu diesem Zeitpunkt wird die Apply-Methode verwendet:

Optional. Eine Reihe von Argumenten, die an die Funktion übergeben werden sollen.

Sorgen Sie dafür, dass Arrays auch Math.max und Math.min aufrufen.
apply 方法 (Function) (JavaScript)
调用函数,并用指定对象替换函数的 this 值,同时用指定数组替换函数的参数。
apply([thisObj[,argArray]])
thisObj
  可选。 要用作 this 对象的对象。
argArray
Nach dem Login kopieren


Verwandte Empfehlungen:

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

JavaScript aufrufen und anwenden

Das obige ist der detaillierte Inhalt vonEinführung in die Funktionen apply und Math.max() in js. 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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage