vue修飾符capture和self


capture

.capture事件修飾符的作用添加事件偵聽器時使用事件捕獲模式

即是給元素添加一個監聽器,當元素發生冒泡時,先觸發帶有該修飾符的元素。若有多個該修飾符,則由外而內觸發。

就是誰有該事件修飾符,就先觸發誰。(捕獲階段觸發,從外向內,沒有capture修飾符的,從內向外冒泡觸發)

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>.capture事件修飾符</title>
<style type="text/css">
* {
margin: 0 auto;
text-align: center;
line-height: 40px;
}
div {
width: 100px;
}
#obj1 {
background: deeppink;
}
#obj2 {
background: pink;
}
#obj3 {
background: hotpink;
}
#obj4 {
background: #ff4225;
}
</style>
<script src="https://cdn.bootcss.com/vue/2.4.2/vue.min.js"></script>
</head>
<body>
<div id="content">
<div id="obj1" v-on:click.capture="doc(event)">
obj1
<div id="obj2" v-on:click.capture="doc(event)">
obj2
<div id="obj3" v-on:click="doc(event)">
obj3
<div id="obj4" v-on:click="doc(event)">
obj4
<!--。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。點擊obj4的時候,彈出的順序為:obj1、obj2、obj4、obj3;
由於1,2有修飾符,故而先觸發事件,然后就是4本身觸發,最后冒泡事件。
-->
</div>
</div>
</div>
</div>
</div>
<script type="text/javascript">
var content = new Vue({
el: "#content",
data: {
id: ''
},
methods: {
doc(event) {
this.id = event.currentTarget.id;
alert(this.id)
}
}
})
</script>
</body>
</html>

 self只當事件是從偵聽器綁定的元素本身觸發時才觸發回調

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>.capture事件修飾符</title>
    <style type="text/css">
        * {
            margin: 0 auto;
            text-align: center;
            line-height: 40px;
        }
        div{
            width:200px;
        }

    </style>
    <script src="https://cdn.bootcss.com/vue/2.4.2/vue.min.js"></script>
</head>
<body>
<div id="app">
   <div class="box1"  style="background: red;" @click.self="test1">
       box1
       <div class="box2" style="background: yellow;">
           box2
<!--box3點擊觸發test3不會觸發test1,如果去除self修飾符就會觸發,也就是說加了self元素的事件,只有自身觸發才會執行回調,不執行冒泡過來的事件-->
<div class="box3" style="background: pink;" @click.self="test3">box3</div> </div> </div> </div> <script type="text/javascript"> new Vue({ el:'#app', data:{ }, methods:{ test1(){ console.log('box1'); } , test3(){ console.log('box3'); } } }) </script> </body> </html>

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM