一文快速學(xué)會阻止事件冒泡的4種方法(原生js阻止,vue中使用修飾符阻止)
阻止事件冒泡的方法
前端結(jié)構(gòu)
<div id="app"> <div class="father-box" @click="clickFatherBox"> 我是父盒子 <div class="son-box" @click="clickSonBox"> 我是子盒子 </div> </div> </div>
methods: { clickSonBox(){ alert("子盒子") }, clickFatherBox(){ alert("父盒子") } },
事件冒泡:clickSonBox事件發(fā)生時(shí)clickFatherBox事件也被觸發(fā)了
此時(shí)點(diǎn)擊子盒子 對話框彈出兩次
方法1:使用js阻止事件冒泡
clickSonBox(e){ e.stopPropagation(); alert("子盒子") }, //或者 clickSonBox(e){ e.cancelBubble=true alert("子盒子") },
方法2:使用事件修飾符stop
綁定事件時(shí),使用stop修飾符阻止事件冒泡
<div class="father-box" @click="clickFatherBox">我是父盒子 <div class="son-box" @click.stop="clickSonBox"> 我是子盒子 </div> </div>
方法3:使用事件修飾符self
綁定事件時(shí),使用self修飾符 表示只在本元素被點(diǎn)擊時(shí)觸發(fā)
<div class="father-box" @click.self="clickFatherBox"> 我是父盒子 <div class="son-box" @click="clickSonBox"> 我是子盒子 </div> </div>
注意:
self修飾符應(yīng)該在父盒子綁定事件時(shí)使用而不是子盒子! 在父盒子事件使用self,點(diǎn)擊了子盒子,父盒子的點(diǎn)擊事件不會被觸發(fā),即事件沒有冒泡,
self表示只在當(dāng)前元素發(fā)生事件時(shí),事件才觸發(fā)
總結(jié)
到此這篇關(guān)于阻止事件冒泡的4種方法(原生js阻止,vue中使用修飾符阻止)的文章就介紹到這了,更多相關(guān)前端阻止事件冒泡方法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
基于vue實(shí)現(xiàn)一個(gè)神奇的動態(tài)按鈕效果
今天我們將利用vue的條件指令來完成一個(gè)簡易的動態(tài)變色功能按鈕,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2019-05-05詳解在Vue中使用TypeScript的一些思考(實(shí)踐)
這篇文章主要介紹了詳解在Vue中使用TypeScript的一些思考(實(shí)踐),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-07-07