ホームページ > ウェブフロントエンド > jsチュートリアル > JavaScript でのイベント処理をマスターする: 基本から高度なテクニックまで

JavaScript でのイベント処理をマスターする: 基本から高度なテクニックまで

Susan Sarandon
リリース: 2024-12-26 17:47:10
オリジナル
529 人が閲覧しました

Mastering Event Handling in JavaScript: From Basics to Advanced Techniques

JavaScript でのイベント処理

イベント処理は、開発者がクリック、キーの押下、マウスの動きなどのユーザーアクションに応答してインタラクティブな Web ページを作成できるようにする JavaScript の重要な側面です。


1.イベントとは何ですか?

イベントとは、Web ページ内で発生する次のような対話または出来事です。

  • マウス操作: クリック、dblclick、マウスオーバー、マウスアウト
  • キーボード操作: キーダウン、キーアップ、キー押下
  • フォームアクション: 送信、変更、フォーカス
  • ウィンドウのアクション: ロード、サイズ変更、スクロール

JavaScript はこれらのイベントをリッスンし、イベント ハンドラー を使用して特定のアクションで応答します。


2.イベントリスナーの追加

A.インライン HTML 属性の使用

イベント ハンドラーを HTML 要素に直接添付できます。

<button onclick="alert('Button clicked!')">Click Me</button>
ログイン後にコピー
ログイン後にコピー

B. addEventListener メソッドの使用

HTML と JavaScript を分離するため、これが推奨される方法です。

const button = document.querySelector("button");
button.addEventListener("click", function() {
  alert("Button clicked!");
});
ログイン後にコピー
ログイン後にコピー

C. on プロパティの使用

要素のイベント プロパティに関数を割り当てることができます。

const button = document.querySelector("button");
button.onclick = function() {
  alert("Button clicked!");
};
ログイン後にコピー
ログイン後にコピー

3.イベントオブジェクト

イベントが発生すると、JavaScript は便利なプロパティとメソッドを備えたイベント オブジェクトを提供します。

document.querySelector("button").addEventListener("click", function(event) {
  console.log("Event type:", event.type); // Output: click
  console.log("Target element:", event.target); // Output: <button>...</button>
});
ログイン後にコピー
ログイン後にコピー

共通のイベント オブジェクト プロパティ

  • type: イベントのタイプ (クリック、キーダウンなど)。
  • target: イベントをトリガーした要素。
  • currentTarget: イベント ハンドラーがアタッチされる要素。
  • PreventDefault(): デフォルトのアクション (フォーム送信の停止など) を防止します。
  • stopPropagation(): イベントが DOM ツリーにバブルアップするのを停止します。

4.イベントの伝播

A.泡立つ

イベントはターゲット要素から始まり、その祖先までバブルアップします。

document.querySelector("div").addEventListener("click", function() {
  console.log("Div clicked!");
});

document.querySelector("button").addEventListener("click", function(event) {
  console.log("Button clicked!");
});
ログイン後にコピー

ボタンをクリックすると、ボタンと div のイベント ハンドラーの両方が実行されます。

B.キャプチャ中

イベントはルートからターゲット要素まで移動します。

キャプチャを使用するには、addEventListener の 3 番目の引数を true に設定します。

<button onclick="alert('Button clicked!')">Click Me</button>
ログイン後にコピー
ログイン後にコピー

伝播の防止

const button = document.querySelector("button");
button.addEventListener("click", function() {
  alert("Button clicked!");
});
ログイン後にコピー
ログイン後にコピー

5.一般的なイベントの種類

マウスイベント

  • click: 要素がクリックされると起動します。
  • dblclick: 要素がダブルクリックされると起動します。
  • Mouseover: マウス ポインターが要素に入ると起動します。

キーボードイベント

  • keydown: キーが押されたときに発火します。
  • keyup: キーが放されたときに起動します。

フォームイベント

  • submit: フォームが送信されると起動されます。
  • change: フォーム要素の値が変更されると発生します。

ウィンドウイベント

  • load: ページの読み込みが完了すると起動します。
  • サイズ変更: ブラウザ ウィンドウのサイズが変更されたときに起動します。

6.イベントリスナーを削除しています

イベント リスナーを削除するには、removeEventListener メソッドを使用します。

const button = document.querySelector("button");
button.onclick = function() {
  alert("Button clicked!");
};
ログイン後にコピー
ログイン後にコピー

7.実践例: フォームの検証

document.querySelector("button").addEventListener("click", function(event) {
  console.log("Event type:", event.type); // Output: click
  console.log("Target element:", event.target); // Output: <button>...</button>
});
ログイン後にコピー
ログイン後にコピー

8.ベストプラクティス

  1. 柔軟性とコードをクリーンにするために addEventListener を使用します。
  2. 保守性を向上させるために、JavaScript を HTML から分離してください。
  3. イベントの動作を管理するには、stopPropagation とPreventDefault を慎重に使用してください。
  4. メモリ リークを避けるために、イベント リスナーが必要なくなったら削除します。

9.概要

  • JavaScript でのイベント処理により、対話型 Web アプリケーションが可能になります。
  • イベント ハンドラーをアタッチするには addEventListener を使用します。
  • 高度な使用例のイベント オブジェクトと伝播を理解します。
  • 最適なパフォーマンスを得るために、イベント リスナーの適切な管理を実践してください。

イベント処理をマスターすることは、動的でユーザーフレンドリーな Web アプリケーションを構築するための重要なスキルです。

こんにちは、アバイ・シン・カタヤットです!
私はフロントエンドとバックエンドの両方のテクノロジーの専門知識を持つフルスタック開発者です。私はさまざまなプログラミング言語やフレームワークを使用して、効率的でスケーラブルでユーザーフレンドリーなアプリケーションを構築しています。
ビジネス用メールアドレス kaashshorts28@gmail.com までお気軽にご連絡ください。

以上がJavaScript でのイベント処理をマスターする: 基本から高度なテクニックまでの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:dev.to
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート