1. イベント処理モデルイベント バブリングとイベント キャプチャリング: イベント バブリングとイベント キャプチャリングは、それぞれ Microsoft と Netscape によって提案されました。どちらの概念も、ページ内のイベント フロー (イベントが発生する順序) の問題を解決することを目的としています。 <div id="d1"> <div id="d2"> <div id="d3"></div> </div> </div> 3 つのネストされた div がある場合、3 つの要素に同じイベントが登録されると、それらのトリガー順序はどのようになりますか? 1. イベントバブリングMicrosoft は、イベント バブリングと呼ばれるイベント ストリームを提案しました。構造的に(視覚的にではなく)ネストされた要素にはバブリング機能があり、つまり同じイベントが子要素から親要素にバブリングします。 (ボトムアップ) 上記の例では、バブリング方式を使用する場合、トリガー順序は d3——>d2——>d1 となるはずなので、確認してみましょう。 (1)3つのdiv要素にイベントをバインドする//1. 要素を取得する var d1 = document.querySelector('#d1') var d2 = document.querySelector('#d2') var d3 = document.querySelector('#d3') //2. イベントのバインド d1.onclick = function(){ コンソールログ(このID) } d2.onclick = 関数(){ コンソールログ(このID) } d3.onclick = 関数(){ コンソールログ(このID) } (2)運用実績:赤い部分をクリックしてください: 紫色の領域をクリックします。 緑色の領域をクリックします: 以上、イベント盛り上がってます! 2. イベントキャプチャ構造的に(視覚的にではなく)ネストされた要素には、イベント キャプチャの機能があります。つまり、親要素から子要素(イベント ソース要素)に同じイベントがキャプチャされます。 (トップダウン) (つまり、イベントはキャプチャされません) 上記の例では、バブリング方式を使用する場合、トリガー順序は d1——>d2——>d3 となるはずなので、確認してみましょう。 (1)3つのdiv要素にイベントをバインドする//1. 要素を取得する var d1 = document.querySelector('#d1') var d2 = document.querySelector('#d2') var d3 = document.querySelector('#d3') //2. イベントのバインド d1.onclick = function(){ コンソールログ(このID) } d2.onclick = 関数(){ コンソールログ(このID) } d3.onclick = 関数(){ コンソールログ(このID) } (2)運用実績:赤い部分をクリックしてください: 紫色の領域をクリックします。 緑色の領域をクリックします: イベント攻略ゲット!!! 知らせ:
2. イベントのバブルを防ぐ(1) W3C標準のevent.stopPropagation(); ですが、IE9以下ではサポートされていません。//1. 要素を取得する var d1 = document.querySelector('#d1') var d2 = document.querySelector('#d2') var d3 = document.querySelector('#d3') //2. イベントのバインド d1.onclick = function(){ コンソールログ(このID) } d2.onclick = 関数(){ コンソールログ(このID) } d3.onclick = 関数(e){ e.stopPropagation(); コンソールログ(このID) } 緑色の領域をクリックすると、外部イベントが順番にトリガーされず、イベントのバブリングがブロックされることがわかります。 (2) IE固有: event.cancelBubble = true;//1. 要素を取得する var d1 = document.querySelector('#d1') var d2 = document.querySelector('#d2') var d3 = document.querySelector('#d3') //2. イベントのバインド d1.onclick = function(){ コンソールログ(このID) } d2.onclick = 関数(){ コンソールログ(このID) } d3.onclick = 関数(e){ e.cancelBubble = true; コンソールログ(このID) } 結果は(1)と同じである。 (3)マージキャンセル:falseを返すJavaScript では、 要約するこの記事はこれで終わりです。皆さんのお役に立てれば幸いです。また、123WORDPRESS.COM のその他のコンテンツにも注目していただければ幸いです。 以下もご興味があるかもしれません:
|
<<: CSSレイアウトにおけるフローティング問題に対する4つの解決策の詳細な説明
>>: バックアップと削除のためにリアルタイムでステートメントを検出するMySQLトリガーの考え方の詳細な説明
Vue プロジェクトを開発する場合、さまざまなコンポーネント ページを表示するために切り替えることが...
次のグラフは、100 個の異なる要素で iframe を作成するのにどれくらいの時間がかかるかを示し...
1. MySQL 8.0.12 バージョンのインストール手順。 1. ダウンロードhttps://d...
ウェブサイトのナビゲーションを設計することは、家の基礎を築くようなものです。基礎がしっかりしていなけ...
この記事では、MySQL を使用してデータを Excel にエクスポートする方法について説明します。...
1 はじめに「Maven がワンクリックで Springboot を Docker リポジトリにデプ...
この記事では、MySQL の null (IFNULL、COALESCE、NULLIF) に関連する...
目次最初の方法アプリ.vueホーム.vueホームコンテンツ.vueデータの応答性レスポンシブプロパテ...
目次1. マスタースレーブレプリケーションマスタースレーブレプリケーション3スレッドマスタースレーブ...
背景: Linux サーバーのファイルのアップロードとダウンロード。 XShell+Xftp インス...
目次1 コンテナクラウドとは何ですか? 2 Dockerの紹介3 dockerを使ってMySQLをイ...
目次Mysql マスタースレーブ同期構成1. 2つのmysqlをインストールする2. MySQL設定...
1.0 Redis の永続性Redis はメモリ内データベースです。サーバー プロセスが終了すると、...
QQtabBar の BEMまず、BEMとはどういう意味でしょうか? BEM は、ブロック、要素、修...
目次序文1. forループ2. whileループとdo-whileループ3. forEach、map...