1. イベントバブリング: JavaScript イベント伝播のプロセスでは、要素でイベントがトリガーされると、そのイベントはドキュメントまで段階的に先行要素に伝播し、一部のブラウザではウィンドウに到達することがあります。すべてのイベントにバブリングがあるわけではありません。例: 2. イベント委任: イベント キャプチャは、イベント バブリングと正反対です。イベントが要素をトリガーするまで、最上位の祖先要素から開始されます。 js イベント キャプチャは通常、DOM2 イベント モデル
3 番目のパラメータはデフォルトで false に設定されており、イベントがバブリング フェーズでトリガーされることを示します。true に設定すると、キャプチャ フェーズでトリガーされます。一般に、イベント キャプチャは私たちの作業ではほとんど使用されないようです。しかし、まだ理解する必要がある <div id="ボックス"> <div id="middle"> <div id="内部"></div> </div> </div> <スクリプト> //イベントキャプチャ window.onload=function(){ box = document.getElementById("box"); とします。 middle = document.getElementById("middle"); とします。 inner を document.getElementById("inner"); とします。 box.addEventListener("click",function(){console.log("box")},true); middle.addEventListener("click",function(){console.log("middle")},true); inner.addEventListener("click",function(){console.log("inner")},true); } </スクリプト> innerをクリックすると、コンソールにbox、middle、innerと出力されます。 イベントのバブリングを停止 通常、多数のイベントバブリングイベントが使用されますが、特定の子タグでは親にイベントを渡す必要がない場合があります。このとき、そのイベントのバブリングを防ぐ必要があります。 一般的に、stopPropagation はイベントのバブリングを防ぐために使用されます。IE では、cancelBuble=true が使用されます。stopPropagation もイベント オブジェクト (Event) のメソッドです。その機能は、対象要素のイベントのバブリングを防ぐことですが、デフォルトの動作を防ぐことはできません。 //イベントのバブルを防ぐ let btna = document.getElementById('btn'); btna.onclick=関数(e){ window.event? window.event.cancelBubble = true : e.stopPropagation(); }; 3. イベント委任: イベント委任はイベント プロキシとも呼ばれます。イベント委任ではイベント バブリングを利用します。イベント ハンドラーを 1 つだけ指定することで、特定のタイプのすべてのイベントを管理できます。 利点: DOM 操作を減らすと、Web ページのパフォーマンスが向上します。ページの親要素と多くの子要素が同じイベントを操作する必要がある場合、各要素にイベントをバインドすることはできません。 <ul id="getNum"> <li>1</li> <li>2</li> <li>3</li> <li>4</li> <li>5</li> <li>6</li> </ul> <スクリプト> ptclick = document.getElementById('getNum'); とします。 lilist = ptclick.querySelectorAll('li') とします。 for(let i=0;i<lilist.length;i++){ lilist[i].index = i; }; ptclick.onclick = 関数(e){ var e = e || window.event; var ターゲット = e.target || e.srcElement; console.log(e.target.index); }; </スクリプト> 要約するこの記事はこれで終わりです。皆さんのお役に立てれば幸いです。また、123WORDPRESS.COM のその他のコンテンツにも注目していただければ幸いです。 以下もご興味があるかもしれません:
|
>>: HTMLページでよく使われるいくつかの小さなメソッド
この記事ではUbuntuでC++インターフェースを使用してopencvをインストールする方法について...
目次序文スロークエリログの設定テスト付録: ログ解析ツール mysqldumpslow要約する序文こ...
序文group by と distinctive のパフォーマンス比較について: インターネット上の...
div を使用してマスクを作成したり、ポップアップ ウィンドウをシミュレートしたりします。ただし、I...
--データベースに接続するとき、ホストとユーザーのマッチングルール公式ドキュメント: https:/...
目次特徴保存戦略自己増加の決定自動増分値の変更実行プロセス問題点自動増分ロックロック戦略バッチ挿入の...
<> 演算子機能: 等しくないことを示します。注: 「!=」演算子と同じ機能を持ちますが...
この記事では、CSS で放射状グラデーションを使用して、次の図に示すクーポン スタイルの効果を実現す...
#1. ダウンロード # #2. ローカルに解凍し、必要な構成のmy*.iniを変更します。 #3....
目次序文脱構築記号の役割使い方分割割り当ての適用アプリケーションの簡単な紹介JSONデータを抽出する...
最近、ウェブサイトを https アクセスに変換したいのですが、すべて完了した後、Baidu Web...
DockerでNginxイメージをダウンロードする docker プル nginx Docker イ...
DOMとは何ですか? JavaScript を使用すると、HTML ドキュメント全体を再構築できます...
目次仮想DOMとは何ですか?なぜ仮想DOMが必要なのでしょうか?仮想 DOM はどのようにして実際の...
目次1. リソースのダウンロード2. ソフトウェアを解凍する2.1 場所を選択する2.2 名前を変更...