vue綁定的點擊事件阻止冒泡的實例
當我們在使用vue做項目時,經(jīng)常用到點擊事件的綁定,但是我們綁在一個div上,里面的其他按鈕(如刪除、修改)等按鈕也會加載這兒div的點擊事件,而事實我們不需要,如何解決:
首先我們來區(qū)分事件冒泡、事件捕獲是什么
(1)冒泡型事件:事件按照從最特定的事件目標到最不特定的事件目標(document對象)的順序觸發(fā)。
IE 6.0: div -> body -> html -> document
Mozilla 1.0: div -> body -> html -> document -> window
(2)捕獲型事件(event capturing):事件從最不精確的對象(document 對象)開始觸發(fā),然后到最精確(也可以在窗口級別捕獲事件,不過必須由開發(fā)人員特別指定)。
(3)DOM事件流:同時支持兩種事件模型:捕獲型事件和冒泡型事件,但是,捕獲型事件先發(fā)生。兩種事件流會觸及DOM中的所有對象,從document對象開始,也在document對象結(jié)束。
<span style="font-family:SimSun;font-size:14px;"> <div class="tableContent" v-for="(items,index) in dataList" v-on:click="changeBacks(items)" :class="{tableContentHover:items.changeBack}"> <ul> <li><span><label :class="{labelChange:items.changeBack}">√</label></span><label v-html="items.name"></label> </li> <li><label v-html="items.sex"></label></li> <li><label v-html="items.tel"></label></li> <li> <label v-html="items.age" v-if="items.age<=20" v-bind:class="'black'"></label> <label v-html="items.age" v-else-if="items.age<=40" v-bind:class="'green'"></label> <label v-html="items.age" v-else-if="items.age<=60" v-bind:class="'blue'"></label> <label v-html="items.age" v-else-if="items.age<=80" v-bind:class="'purple'"></label> <label v-html="items.age" v-else v-bind:class="'red'"></label> </li> <li><label v-html="items.profession"></label></li> <li><button v-on:click.stop="deleteThis(index)">刪除</button></li> </ul> </div></span>
這個時候在button的點擊事件加上.stop,就可以解決以上問題。
以上這篇vue綁定的點擊事件阻止冒泡的實例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
VUE+Element UI實現(xiàn)簡單的表格行內(nèi)編輯效果的示例的代碼
這篇文章主要介紹了VUE+Element UI實現(xiàn)簡單的表格行內(nèi)編輯效果的示例的代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-10-10詳解基于 axios 的 Vue 項目 http 請求優(yōu)化
這篇文章主要介紹了詳解基于 axios 的 Vue 項目 http 請求優(yōu)化,非常具有實用價值,需要的朋友可以參考下2017-09-09Vue.js在數(shù)組中插入重復(fù)數(shù)據(jù)的實現(xiàn)代碼
這篇文章主要介紹了Vue.js在數(shù)組中插入重復(fù)數(shù)據(jù)的實現(xiàn)代碼,需要的朋友可以參考下2017-11-11Vue使用emit傳參,父組件接收不到數(shù)據(jù)的問題及解決
這篇文章主要介紹了Vue使用emit傳參,父組件接收不到數(shù)據(jù)的問題及解決,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-09-09基于vue-cli3多頁面開發(fā)apicloud應(yīng)用的教程詳解
這篇文章主要介紹了基于vue-cli3多頁面開發(fā)apicloud應(yīng)用,本文采用vue-cli+APIcloud的方式寫解決以上痛點,開發(fā)靈活,并且打包之后體積更小速度更快,需要的朋友可以參考下2019-06-06