ホームページ ウェブフロントエンド jsチュートリアル DOMイベントフローの詳しい解説_基礎知識

DOMイベントフローの詳しい解説_基礎知識

May 16, 2016 pm 04:18 PM
dom

1. バブルイベント

ブラウザのイベント モデルは、キャプチャ イベントとバブリング イベントの 2 つのタイプに分類されます。 IE はイベントのキャプチャをサポートしていないため、以下では主にバブリング イベントを説明として使用します。
(バブリングと呼ばれます) バブリングとは、最も具体的なイベントから最も具体性の低いイベントまで、イベントが 1 つずつトリガーされることを意味します。

コードをコピーします コードは次のとおりです:



')">クリックしてください


                                                                                       

<スクリプトタイプ="text/javascript">
関数 add(sText) {
var ulo = document.getElementById("display");
ulo.innerHTML = sText;
}


上記の 3 つの関数はすべて、onclick 関数を追加します。最初に p 要素が実行され、次に div が実行され、最後に body が実行された後にトリガーされます。

ところで、ここでイベントのキャプチャについて思い出させてください。その順序はバブリングイベントとはまったく逆です。

2. イベント監視

イベントには応答する関数が必要です。この種の関数は通常、イベント ハンドラーと呼ばれ、イベントが発生するかどうかをリアルタイムで監視します。イベント リスニング機能はブラウザーごとに大きく異なります。

i. onclick メソッドの使用など、ほとんどすべてのタグがこのメソッドをサポートしています。そしてブラウザの互換性も非常に高いです

行動の説明、イベントの分離。

一般的に、監視には次の方法が使用されます

コードをコピーします コードは次のとおりです:
クリック

<スクリプトタイプ="text/javascript">
var opp = document.getElementById("me") // イベントを検索
opp.onclick = function(){ //イベント関数を設定
alert("クリックされました!")
}




上で紹介した 2 つのメソッドは非常に便利で、いくつかの小さな関数を作成および処理するときに Everbright 開発者に愛用されています。ただし、同じイベントの場合。 p マークの onclick 関数など、追加できる関数は 1 つだけです。そのため、IE には独自のメソッドが用意されています。

ii.IEでのリスニング方法

初期の IE ブラウザでは、各要素に時間監視を処理する 2 つのメソッドがあります。

それぞれ、attachEvent() と detachEnevt() です。
関数名からも分かるように、attachEnevt()は要素にイベント処理を追加する関数であり、detachEvent()は要素のlisten関数を削除する関数です。構文は次のとおりです:

[オブジェクト].attachEvent("enevt_handler","fnHandler");

[オブジェクト].detachEvent("enevt_handler","fnHandler");

このうち enevt_handler はよく使われる onclick、onload、onmouseover などを表します。
fnHandler は、リスニング関数の名前です。
前のセクションのイベントでは、リッスン関数を追加する代わりに、attachEvent() メソッドを使用して、一度クリックしたときにリッスン関数を削除し、次のクリック後にリスニング関数が実行されないようにすることができます。 。

コードをコピー コードは次のとおりです:

<スクリプトタイプ="text/javascript">
関数 fnclick() {
alert("クリックされました!");
oP.detachEvent("onclick","fnclick");
}
var oP;
window.onload = function() {
oP = document.getElementById("oop") // オブジェクトが見つかりました
Op.attachevent ("Onclick", "FNCLICK") // 監視機能を追加します

}
                                                                                                                                                                             



                                                                                       


iii. 複数のリスニング イベントを追加します (つまり)

コードをコピーします

コードは次のとおりです: <スクリプト言語="javascript"> 関数 fnClick1(){
alert("fnClick1 によってクリックされました");
}
関数 fnClick2(){
alert("fnClick2 によってクリックされました");
//oP.detachEvent("onclick",fnClick1) //リスニング関数 1
を削除します。 }
var oP;
window.onload = function(){
oP = document.getElementById("myP"); // オブジェクトが見つかりました
oP.attachEvent("onclick",fnClick1); //リスニング関数を追加 1
oP.attachEvent("onclick",fnClick2) //リスニング関数2を追加
}





                                                                                                                                                                                                                           



3. 標準 DOM イベント監視

ie の 2 つのメソッドと比較すると、標準 DOM も 2 つのメソッドを使用してそれぞれリスニング関数を追加および削除します。それはaddEventListener()とremoveEventListener()

です。 ie とは異なり、これら 2 つの関数は 3 つのパラメーター、つまりイベントの名前、割り当てられる関数名、およびバブリングフェーズで使用されるかキャプチャフェーズで使用されるかどうかを受け入れます。キャプチャ フェーズのパラメータは true、バブリング フェーズのパラメータは false です。構文は次のとおりです:

コードをコピーします

コードは次のとおりです: [オブジェクト].addEventListener("イベント名",fnHandler,bCapture); [オブジェクト].removeEventListener("イベント名",fnHandler,bCapture);

これら 2 つの関数の使い方は基本的に Ie と同様ですが、event_name の名前が Ie では "onclick"、"onmouseover" ではなく "click"、"mouseover" などになっていることに注意してください。

さらに、3 番目のパラメーター bCapture は通常 false、バブリング段階に設定されます。
標準の DOM イベント リスニング方法:

コードをコピー

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

vue dom とはどういう意味ですか? vue dom とはどういう意味ですか? Dec 20, 2022 pm 08:41 PM

DOM はドキュメント オブジェクト モデルであり、HTML プログラミング用のインターフェイスであり、ページ内の要素は DOM を通じて操作されます。 DOM は HTML ドキュメントのメモリ内オブジェクト表現であり、JavaScript を使用して Web ページと対話する方法を提供します。 DOM は、ドキュメント ノードをルートとするノードの階層 (またはツリー) です。

vue3 で dom またはコンポーネントへの ref バインディングが失敗する理由とその解決方法は何ですか? vue3 で dom またはコンポーネントへの ref バインディングが失敗する理由とその解決方法は何ですか? May 12, 2023 pm 01:28 PM

Vue3ref バインディング DOM またはコンポーネントの失敗理由分析シナリオの説明 Vue3 では、コンポーネントまたは DOM 要素をバインドするために ref を使用することがよくありますが、関連するコンポーネントをバインドするために ref が明確に使用されていることがよくありますが、ref バインディングが失敗することがよくあります。 ref バインディングが失敗する状況の例 ref バインディングが失敗するほとんどのケースは、ref がコンポーネントにバインドされているときにコンポーネントがまだレンダリングされていないため、バインディングが失敗することです。または、コンポーネントが最初にレンダリングされず、ref がバインドされていない場合、コンポーネントのレンダリングが開始されると、ref もバインドされ始めますが、ref とコンポーネントの間のバインディングが完了していません。このとき、問題が発生します。コンポーネント関連のメソッドを使用する場合。 ref にバインドされたコンポーネントが v-if を使用するか、その親コン​​ポーネントが v-if を使用してページに

Vue3 で DOM ノードを取得する方法は何ですか? Vue3 で DOM ノードを取得する方法は何ですか? May 11, 2023 pm 04:55 PM

1. ネイティブ js は DOM ノードを取得します。 document.querySelector (セレクター) document.getElementById (id セレクター) document.getElementsByClassName (クラス セレクター).... 2. vue2 で現在のコンポーネントのインスタンス オブジェクトを取得します。コンポーネント インスタンスには、対応する DOM 要素またはコンポーネントへの参照を保存する $refs オブジェクトが含まれています。したがって、デフォルトでは、コンポーネントの $refs は空のオブジェクトを指します。まず ref="name" をコンポーネントに追加してから、this.$refs を渡します。

dom オブジェクトと bom オブジェクトとは何ですか? dom オブジェクトと bom オブジェクトとは何ですか? Nov 13, 2023 am 10:52 AM

DOM オブジェクトは「ドキュメント」、「要素」、「ノード」、「イベント」、「ウィンドウ」の 5 つ、2.「ウィンドウ」、「ナビゲーター」、「場所」、「履歴」、「画面」、その他 5 つです。 BOM オブジェクト。

PHP での DOM 操作ガイド PHP での DOM 操作ガイド May 21, 2023 pm 04:01 PM

Web 開発において、DOM (DocumentObjectModel) は非常に重要な概念です。これにより、開発者は要素の追加、削除、変更など、Web ページの HTML または XML ドキュメントを簡単に変更および操作できるようになります。 PHP に組み込まれている DOM 操作ライブラリも開発者向けに豊富な機能を提供していますので、この記事では、皆様のお役に立てればと思い、PHP での DOM 操作ガイドを紹介します。 DOM の基本概念 DOM は、クロスプラットフォームで言語に依存しない API です。

ボムとドムの違いは何ですか ボムとドムの違いは何ですか Nov 13, 2023 pm 03:23 PM

BOM と DOM は、役割と機能、JavaScript との関係、相互依存性、さまざまなブラウザーの互換性、セキュリティ上の考慮事項の点で異なります。詳細な紹介: 1. 役割と機能: BOM の主な機能はブラウザ ウィンドウを操作することであり、ブラウザ ウィンドウへの直接アクセスと制御を提供しますが、DOM の主な機能は Web ドキュメントをオブジェクト ツリーに変換し、開発者は、このオブジェクト ツリーを使用して Web ページの要素やコンテンツを取得および変更します。 2. JavaScript などとの関係

DOM の組み込みオブジェクトとは何ですか? DOM の組み込みオブジェクトとは何ですか? Dec 19, 2023 pm 03:45 PM

dom内置オブジェクトの内容:1、document;2、window;3、navigator;4、location;5、history;6、screen;7、document.documentElement;8、document.body;9、document.head;10、document .title;11、document.cookie。

dom と bom は何を実現しますか? dom と bom は何を実現しますか? Nov 20, 2023 pm 02:28 PM

DOM は Web ページ コンテンツへの動的なアクセスと更新を可能にし、BOM はブラウザの動作の制御やブラウザとユーザー環境に関する情報の取得など、ブラウザ ウィンドウと対話するための API を提供します。DOM は主に Web ページ コンテンツの操作に使用され、BOM は主に使用されますブラウザ ウィンドウの操作とブラウザとの対話。この 2 つは共に Web フロントエンド開発の重要な基盤を形成し、開発者に Web ページとブラウザを制御および操作して強力な対話性と優れたユーザー エクスペリエンスを備えた Web アプリケーションを実現するための豊富な方法を提供します。

See all articles