ホームページ  >  記事  >  ウェブフロントエンド  >  イベントの委任とバブリングの防止により、親要素のイベントがtriggering_jqueryから阻止されます。

イベントの委任とバブリングの防止により、親要素のイベントがtriggering_jqueryから阻止されます。

WBOY
WBOYオリジナル
2016-05-16 16:38:031427ブラウズ

イベントの委任とバブリングの防止について簡単に説明します

html:

<ul class="clearfix" data-type="cityPick"> 
<li class="active_sort_opts" data-id="0">全部</li> 
<li data-id="88">纽约</li> 
<li data-id="119">洛杉矶</li> 
<li data-id="138">拉斯维加斯</li> 
<li data-id="84">夏威夷</li> 
<li data-id="120">旧金山</li> 
<li data-id="105">奥兰多</li> 
<li data-id="118">西雅图</li> 
</ul>

js:

$("ul[data-type='cityPick']").on('click',function(){ 
alert("父元素ul被点击"); 
}); 
$("ul[data-type='cityPick']").on('click','li',function(){ 
alert("子元素li被点击"); 
});

特定の li 要素をクリックすると、ul イベントもトリガーされることがわかりますが、これは望ましくないことです。

解決策:

$("ul[data-type='cityPick']").on('click',function(){ 
alert("父元素ul被点击"); 
}); 
$("ul[data-type='cityPick']").on('click','li',function(e){ 
e.stopPropagation();//阻止冒泡 
alert("子元素li被点击"); 
});

文を追加するだけでバブルが止まります。

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