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ページでよく使われるいくつかの小さなメソッド
開発中に以下の状況が発見されました。 (1) ファイルが.jspファイル拡張子で保存されている場合、...
「curl-config を実行できませんでした」の解決策 pycurl のダウンロード/解凍 (p...
mysql マスタースレーブ構成1. 準備ホスト: 192.168.244.128スレーブ: 192...
パスワード強度検証について: [root@mysql mysql]# mysql -uroot -p...
MySQL を使用する場合、多くの開発者は一部の列に対して関数計算を実行することが多く、その結果、イ...
目次1. JavaScriptで配列を作成する方法2. 配列メソッドの概要3. 方法の詳細な説明1....
この記事では、MySQL 5.7.21 のインストールと設定方法を記録し、皆様と共有します。 1. ...
序文binlog は、MySQL のすべての追加、削除、および変更ステートメントを記録するバイナリ ...
SQL 左結合、右結合、内部結合、自然結合 さまざまな結合の概要SQL には、左結合、右結合、内部結...
Mac で Docker を使用して Oracle をデプロイする方法まずdockerをインストール...
HTML 初心者は、ファイルを正しく参照する方法という問題によく遭遇します。たとえば、HTML ペー...
目次インストール手順環境設定実行構成インストール手順ダウンロードアドレス: バージョン6.0 最初に...
前回の記事で、mysqldump バックアップ ファイルに記録されるタイムスタンプ データは UTC...
MySQL ストアド プロシージャ1. ストアドプロシージャ構文(フォーマット)を作成する 区切り文...
目次序文実装のアイデア実装手順1. Nginxをコンパイルする2. 設定ファイルは以下のとおりです要...