事件修饰符:
- .stop 阻止冒泡
- .prevent 阻止默认事件
- .capture 添加事件侦听器时使用事件捕获模式
- .self 只当事件在该元素(比如不是子元素)触发时触发回调
- .once 只触发一次
.stop 阻止冒泡
<!--使用.stop 阻止冒泡-->
<div class="inner" @click="divHandler">
<input type="button" value="点击" @click.stop="btnHandler">
</div>
.prevent 阻止默认事件
<!--使用.prevet 阻止默认事件-->
<a href="http://baidu.com" target="_blank" rel="noopener noreferrer" @click.prevent="linkclick">点击百度</a>
.capture 添加事件侦听器时使用事件捕获模式
<!--使用.capture 实现捕获触发事件的机制(从外到里捕获事件)-->
<div class="inner" @click.capture="divHandler">
<input type="button" value="点击" @click.stop="btnHandler">
</div>
self 只当事件在该元素(比如不是子元素)触发时触发回调
<!--使用.self 实现只有点击当期元素,才会触发事件函数-->
<div class="inner" @click.self="divHandler">
<input type="button" value="点击" @click.stop="btnHandler">
</div>
.once 只触发一次
<!--使用.once 事件只触发一次处理函数 .prevent.once 顺序无所谓-->
<a href="http://baidu.com" target="_blank" rel="noopener noreferrer" @click.prevent.once="linkclick">点击百度</a>
使用.stop 与.self的区别
.self只会阻止自己身上的冒泡的行为触发,不会阻止别人的触发
<!--使用.stop 阻止冒泡-->
<div class="outer" @click="div2Handler">
<div class="inner" @click="divHandler">
<input type="button" value="点击" @click.stop="btnHandler">
</div>
</div>
<!--使用 .self 阻止冒泡-->
<div class="outer" @click="div2Handler">
<div class="inner" @click.self="divHandler">
<input type="button" value="点击" @click="btnHandler">
</div>
</div>
完成代码示例
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<script src="./vue.js"></script>
<style>
.inner{
height: 150px;
background-color: darkcyan;
margin: 15px 0
}
.outer{
padding: 40px;
background-color: red;
margin: 15px 0
}
</style>
</head>
<body>
<div id="app">
<!--使用.stop 阻止冒泡-->
<div class="inner" @click="divHandler">
<input type="button" value="点击" @click.stop="btnHandler">
</div>
<!--使用.prevet 阻止默认事件-->
<a href="http://baidu.com" target="_blank" rel="noopener noreferrer" @click.prevent="linkclick">点击百度</a>
<!--使用.capture 实现捕获触发事件的机制(从外到里捕获事件)-->
<div class="inner" @click.capture="divHandler">
<input type="button" value="点击" @click.stop="btnHandler">
</div>
<!--使用.self 实现只有点击当期元素,才会触发事件函数-->
<div class="inner" @click.self="divHandler">
<input type="button" value="点击" @click.stop="btnHandler">
</div>
<!--使用.once 事件只触发一次处理函数 .prevent.once 顺序无所谓-->
<a href="http://baidu.com" target="_blank" rel="noopener noreferrer" @click.prevent.once="linkclick">点击百度</a>
<!--使用.stop 与.self的区别
.self只会阻止自己身上的冒泡的行为触发,不会阻止别人的触发
-->
<!--使用.stop 阻止冒泡-->
<div class="outer" @click="div2Handler">
<div class="inner" @click="divHandler">
<input type="button" value="点击" @click.stop="btnHandler">
</div>
</div>
<!--使用 .self 阻止冒泡-->
<div class="outer" @click="div2Handler">
<div class="inner" @click.self="divHandler">
<input type="button" value="点击" @click="btnHandler">
</div>
</div>
</div>
<script>
var vm= new Vue({
el: '#app',
data:{
},
methods:{
divHandler(){
console.log('触发inner div的点击事件')
},
btnHandler(){
console.log('触发btn 的点击事件')
},
linkclick()
{
console.log('触发link的点击事件')
},
div2Handler(){
console.log('触发outer 的点击事件')
}
}
});
</script>
</body>
</html>