Vue学习(五): 事件修饰符

事件修饰符:

  1. .stop 阻止冒泡
  2. .prevent 阻止默认事件
  3. .capture 添加事件侦听器时使用事件捕获模式
  4. .self 只当事件在该元素(比如不是子元素)触发时触发回调
  5. .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>