Function.prototype.apply と Function.prototype.call は、特定の this 値を使用して関数を呼び出すことができるメソッドです。パラメーター。 2 つの主な違いは、apply ではパラメータの配列を渡すことができるのに対し、call ではパラメータを 1 つずつリストする必要があることです。
Function .prototype.apply は、特定の this 値と引数配列を使用して関数を呼び出すことができるメソッドです。
apply を使用するための構文は -
func.apply(thisArg, argsArray)
です。ここで、thisArg は関数内で this として使用される値です。 argsArray は、関数に渡される引数の配列です。
次は、apply -
<!doctype html> <html> <head> <title>Examples</title> </head> <body> <div id="result"></div> <script> function sayHello(name) { return "Hello, " + name + "!"; } document.getElementById("result").innerHTML = sayHello.apply(null, ["John"]) </script> </body> </html>
を使用して関数を呼び出す例です。上記のコードは次の出力を出力します。
Hello, John!
ご覧のとおり、この値を設定したくないため、thisArg に null を渡しました。パラメータ「John」を含む argsArray の配列を渡しました。結果は、name パラメーターとして「John」を使用して、sayHello 関数を呼び出します。
Function.prototype.call は、特定の this 値とパラメーター リストを使用してメソッドを呼び出すことができる関数です。
call を使用するための構文は
func.call(thisArg, arg1, arg2, ...)
です。thisArg は関数内で this として使用される値です。 arg1、arg2、 ... は、関数に渡されるパラメーターです。
call を使用した例は次のとおりです 関数の呼び出し -
<!doctype html> <html> <head> <title>Examples</title> </head> <body> <div id="result"></div> <script> function sayHello(name) { return "Hello, " + name + "!"; } document.getElementById("result").innerHTML = sayHello.call(null, ["John"]) </script> </body> </html>
上記のコードは次の出力を出力します。 。
Hello, John!
ご覧のとおり、この値を設定したくないため、thisArg に null を渡しました。 「John」を唯一のパラメータとして使用します。結果は、name パラメーターとして「John」を使用して、sayHello 関数を呼び出します。
次の表は、Function.prototype.apply と Function.prototype.call-
## の主な違いを示しています。Function.prototype.apply | Function.prototype.call | ||
---|---|---|---|
このメソッドを使用すると、特定の | this 値と引数配列を使用して関数を呼び出すことができます。 | このメソッドを使用すると、特定のthis 値と引数リストを使用して関数を呼び出すことができます。 | |
パラメータの配列を渡します。 | パラメータリストを渡します。 | ||
新しい関数を作成しないため、 | を呼び出すよりも高速です。 | em>呼び出しごとに新しい関数が作成されるため、 | apply よりも遅くなります。 |
|
#リンクされたオブジェクトのコンストラクター。
|
以上がJavaScript における Function.prototype.apply と Function.prototype.call の違いの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。