「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > JavaScript をマスターする: 呼び出し、適用、バインドを理解します。

JavaScript をマスターする: 呼び出し、適用、バインドを理解します。

2024 年 8 月 19 日に公開
ブラウズ:457

Mastering JavaScript: Understanding call, apply, and bind.

JavaScript は、現代の Web 開発のバックボーンを形成する多用途で強力なプログラミング言語です。開発者は JavaScript の開発を進めるにつれて、コーディング スキルを大幅に向上させる、より高度な概念に遭遇します。これらの概念には、call、apply、bind メソッドがあります。これらのメソッドは、関数の実行コンテキストを操作し、this キーワードを管理するために不可欠なツールです。この記事では、これらのメソッドを詳しく調べ、その違いを理解し、JavaScript プロジェクトで効果的に使用する方法を学びます。

関数コンテキストの理解 (これ)

呼び出し、適用、バインドについて詳しく説明する前に、JavaScript の this キーワードの概念を理解することが重要です

これは、現在の関数を実行しているオブジェクトを指します。この値は、関数の呼び出し方法によって異なります:

  • オブジェクトのメソッド内で、オブジェクトを参照します。
  • 関数内では、グローバル オブジェクト (ブラウザのウィンドウ) を指します。
  • イベントでは、イベントを受け取った要素を指します。
  • 厳密モード (「厳密な使用」;) では、これは関数で定義されていません。

ただし、この値を手動で設定する必要がある場合があります。そこで、呼び出し、適用、バインドが機能します。

呼び出しメソッド

call メソッドは、特定の this 値と個別に指定された引数を使用して関数を呼び出すために使用されます。これは、別のオブジェクトからメソッドを借用したり、コンテキストを動的に設定したりする場合に特に便利です。その構文は次のとおりです:

function.call(thisArg, arg1, arg2, ...)

call() がどのように機能するかを示す例を次に示します:

const person = {
  fullName: function(city, country) {
    console.log(this.firstName   " "   this.lastName   " lives in "   city   ", "   country);
  }
};

const john = {
  firstName: "John",
  lastName: "Doe"
};

person.fullName.call(john, "New York", "USA");
// Output: John Doe lives in New York, USA

この例では、call() を使用して、john を this 値として fullName 関数を呼び出し、実質的に person オブジェクトからメソッドを借用します。

apply メソッド

apply() メソッドは call() に似ていますが、引数を配列として受け取ります。その構文は次のとおりです:

function.apply(thisArg, [argsArray])

例を見てみましょう。

const person = {
  fullName: function(city, country) {
    console.log(this.firstName   " "   this.lastName   " lives in "   city   ", "   country);
  }
};

const john = {
  firstName: "John",
  lastName: "Doe"
};

person.fullName.apply(john, ["New York", "USA"]);
// Output: John Doe lives in New York, USA

call() と apply() の主な違いは、引数の処理方法です。 call() は引数が個別に渡されることを期待しますが、apply() は引数が配列で渡されることを期待します。

バインドメソッド

関数をすぐに呼び出す call() や apply() とは異なり、bind() はこの値を固定して新しい関数を作成します。これは、後で特定のコンテキストで呼び出すことができる関数を作成する場合に特に便利です。その構文は次のとおりです:

const boundFunction = function.bind(thisArg, arg1, arg2, ...)

これは、bind() がどのように動作するかの例です:

const person = {
  firstName: "John",
  lastName: "Doe",
  fullName: function() {
    return this.firstName   " "   this.lastName;
  }
};

const logName = function() {
  console.log(this.fullName());
};

const boundLogName = logName.bind(person);
boundLogName(); // Output: John Doe

この例では、this 値として person を永続的にバインドする新しい関数boundLogName を作成します。

比較と使用例

  • call: 関数を呼び出して this コンテキストをすぐに制御し、引数を個別に渡す必要がある場合に使用します。
  • apply: call と似ていますが、引数の配列がある場合に使用します。
  • bind: 後で特定の this コンテキストで呼び出すことができる関数を作成する必要がある場合に使用します。

パフォーマンスに関する考慮事項

呼び出し、適用、バインドは強力なツールですが、パフォーマンスへの影響を考慮することが重要です。通常、bind() は新しい関数を作成するため、call() や apply() よりも遅くなります。コードのパフォーマンスが重要なセクションで作業している場合は、bind() の代わりに call() または apply() を使用するとよいでしょう。

ベストプラクティスとよくある落とし穴

呼び出し、適用、バインドを使用する場合は、次のベスト プラクティスに留意してください:

  • 関数内でこれが何を参照するかを常に明確にしてください。
  • 特定の this 値を使用して関数をすぐに呼び出したい場合は、call() または apply() を使用します。
  • 後で使用するためにこの値を固定して新しい関数を作成する場合は、bind() を使用します。
  • アロー関数には変更できない字句 this バインディングがあるため、これらのメソッドをアロー関数で使用する場合は注意してください。

よくある落とし穴は、bind() が新しい関数を返すことを忘れていることです。バインドされた関数を再割り当てするか、直接使用してください

結論

呼び出し、適用、バインドをマスターすることは、熟練した JavaScript 開発者になるための重要なステップです。これらのメソッドは、関数の実行コンテキストを制御し、this キーワードを管理するための強力な方法を提供します。これらのツールを理解し、効果的に使用することで、より柔軟で再利用可能で保守しやすいコードを作成できます。

JavaScript の探索を続ける場合、これらの概念は氷山の一角にすぎないことを忘れないでください。言語は常に進化しており、最新の機能とベスト プラクティスを常に最新の状態に保つことが重要です。プロジェクトで呼び出し、適用、バインドの使用を練習すると、よりエレガントで効率的な JavaScript コードを作成できるようになります。

リリースステートメント この記事は次の場所に転載されています: https://dev.to/sagarj521/mastering-javascript- Understanding-call-apply-and-bind-4ba5?1 侵害がある場合は、[email protected] に連絡して削除してください。
最新のチュートリアル もっと>
  • Go で HTTP POST リクエストの進行状況を追跡する方法は?
    Go で HTTP POST リクエストの進行状況を追跡する方法は?
    Go での HTTP POST リクエストの進行状況の追跡POST リクエスト経由で大きなファイルや画像を送信する場合、開発者はアップロードの進行状況を追跡する際に課題に直面することがよくあります。 。この質問では、Go アプリケーションでそのようなリクエストの進行状況を監視するための信頼できる方法...
    プログラミング 2024 年 11 月 6 日に公開
  • Java でフォルダーからファイル名のリストを取得するにはどうすればよいですか?
    Java でフォルダーからファイル名のリストを取得するにはどうすればよいですか?
    Java を使用してフォルダー内のファイル名を取得するディレクトリ内のファイル名のリストを取得するタスクは、さまざまな環境で共通の要件です。プログラミングシナリオ。 Java でこれを実現するには、File クラスを利用する簡単なアプローチがあります。コード アプローチ:まず、目的のディレクトリ パ...
    プログラミング 2024 年 11 月 6 日に公開
  • Angular Pipes: 包括的なガイド
    Angular Pipes: 包括的なガイド
    Angular の Pipes は、基になるデータを変更せずにテンプレート内のデータを変換するために使用される単純な関数です。パイプは値を受け取り、それを処理し、フォーマットされた出力または変換された出力を返します。これらは、日付、数値、文字列、さらには配列やオブジェクトの書式設定によく使用されます...
    プログラミング 2024 年 11 月 6 日に公開
  • Tailwind CSS とダークモード
    Tailwind CSS とダークモード
    この記事では、Tailwind CSS で ダーク モードを実装する方法を検討します。ダーク モードは、暗い環境でも優れたユーザー エクスペリエンスを提供し、目の疲れを軽減するため、人気のデザイン トレンドになっています。 Tailwind では、組み込みユーティリティを使用してダーク モードを簡単...
    プログラミング 2024 年 11 月 6 日に公開
  • CakePHP の Find メソッドを使用して JOIN クエリを実行するにはどうすればよいですか?
    CakePHP の Find メソッドを使用して JOIN クエリを実行するにはどうすればよいですか?
    JOIN を使用した CakePHP の Find メソッドCakePHP の find メソッドは、テーブルの結合など、データベースからデータを取得する強力な方法を提供します。この記事では、CakePHP の find メソッドを使用して JOIN クエリを実行する 2 つの方法を説明します。方法...
    プログラミング 2024 年 11 月 6 日に公開
  • 結果を再計算したり保存したりせずに、Python でジェネレーターを再利用するにはどうすればよいですか?
    結果を再計算したり保存したりせずに、Python でジェネレーターを再利用するにはどうすればよいですか?
    リセットによる Python でのジェネレーターの再利用Python では、ジェネレーターは要素のシーケンスを反復処理するための強力なツールです。ただし、反復が開始されると、ジェネレーターを巻き戻すことはできません。ジェネレーターを複数回再利用する必要がある場合、これが問題になる可能性があります。ジ...
    プログラミング 2024 年 11 月 6 日に公開
  • JavaScript 開発者向けのトップ S コード拡張機能
    JavaScript 開発者向けのトップ S コード拡張機能
    JavaScript は急速に進化しており、JavaScript を取り巻くツールのエコシステムも急速に進化しています。 開発者は、ワークフローをできるだけ効率的かつスムーズにしたいと考えています。そこで Visual Studio Code (VS Code) が登場します。 JavaScript...
    プログラミング 2024 年 11 月 6 日に公開
  • 計算結果を表示するための HTML 出力タグの使用方法。
    計算結果を表示するための HTML 出力タグの使用方法。
    おかえり!みんなが週末を楽しんだことを願っています。今日は、HTML タグに戻り、 タグに焦点を当てましょう。 タグとは何ですか? タグは計算結果を表示するために使用します。これはインライン要素であり、、、またはその他のインライン要素内に配置できます。これは、計算の結果を表示したり、...
    プログラミング 2024 年 11 月 6 日に公開
  • Java : 変数、データ型、入出力について理解する
    Java : 変数、データ型、入出力について理解する
    導入: Java は世界で最も人気があり多用途なプログラミング言語の 1 つで、Web アプリケーションからモバイル アプリケーションまであらゆるものに使用されています。 Java への取り組みを開始する場合は、基本を理解することが不可欠です。このガイドでは、Java プログラムの...
    プログラミング 2024 年 11 月 6 日に公開
  • 高さに基づいて Div のアスペクト比を維持するにはどうすればよいですか?
    高さに基づいて Div のアスペクト比を維持するにはどうすればよいですか?
    高さに基づいて Div のアスペクト比を維持するWeb デザインでは、要素のアスペクト比を制御することがレスポンシブ レイアウトにとって重要です。この質問では、div の幅をその高さのパーセンテージとして維持し、高さが変化しても要素の形状が一貫していることを保証する方法を検討します。従来のアプローチ...
    プログラミング 2024 年 11 月 6 日に公開
  • Flet での DatePicker の処理
    Flet での DatePicker の処理
    DatePicker の実装をリクエストするためのプロジェクトです。 Flet の公式ドキュメントを参照してください。 import datetime import flet as ft def main(page: ft.Page): page.horizontal_alignment =...
    プログラミング 2024 年 11 月 6 日に公開
  • 円形の SVG マスクに合わせて画像のサイズを変更するにはどうすればよいですか?
    円形の SVG マスクに合わせて画像のサイズを変更するにはどうすればよいですか?
    円形の SVG パスに合わせて画像のサイズを変更するSVG パスを使用して画像から円形の部分を切り取る場合、次のことが重要です。適切な位置合わせを確保するために。画像がうまくフィットしない場合は、SVG マスクのサイズまたは位置が間違っていることが原因である可能性があります。望ましい結果を達成するた...
    プログラミング 2024 年 11 月 6 日に公開
  • 技術面接の質問 - パート タイプスクリプト
    技術面接の質問 - パート タイプスクリプト
    Introduction Hello, hello!! :D Hope you’re all doing well! How we’re really feeling: I’m back with the second part of this series. ? In this...
    プログラミング 2024 年 11 月 6 日に公開
  • Laravel Eloquentで一意の「seller_id」ごとに最大の「created_at」を持つ行を選択する方法は?
    Laravel Eloquentで一意の「seller_id」ごとに最大の「created_at」を持つ行を選択する方法は?
    Laravel Eloquent: 最大値を持つ行を選択する Created_atLaravel Eloquent では、最大値を持つすべての行を選択する必要があるシナリオが発生する場合があります。テーブル内の一意の各eller_id の created_at 値。これを実現する方法は次のとおりです...
    プログラミング 2024 年 11 月 6 日に公開
  • ReactJS での遅延読み込み: 開発者ガイド
    ReactJS での遅延読み込み: 開発者ガイド
    遅延読み込みは ReactJS の強力なテクニックで、必要なときにのみコンポーネントや要素を読み込むことができ、Web アプリケーションのパフォーマンスを向上させます。この記事では、遅延読み込みの概念とその利点、そして組み込みの React.lazy() と React.Suspense を使用して...
    プログラミング 2024 年 11 月 6 日に公開

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3