Maison > Article > interface Web > La délégation d'événements et la prévention du bouillonnement empêchent son événement d'élément parent de triggering_jquery
Parlez brièvement de la délégation d'événements et de la prévention des bulles
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被点击"); });
En cliquant sur un élément li spécifique, on constate que l'événement ul est également déclenché, ce que nous ne voulons pas voir.
Solution :
$("ul[data-type='cityPick']").on('click',function(){ alert("父元素ul被点击"); }); $("ul[data-type='cityPick']").on('click','li',function(e){ e.stopPropagation();//阻止冒泡 alert("子元素li被点击"); });
Ajoutez simplement une phrase pour arrêter de bouillonner.