vue中的事件修饰符(.stop、.prevent、.self、.capture、.once)

摘要:使用.stop阻止事件的冒泡行为。使用.prevent阻止事件的默认行为。使用.self实现只有点击当前元素才会触发事件处理函数。使用.capture实现捕获触发事件的机制,即从外部事件开始执行。使用.once实现事件的触发次数为一次。

摘要

使用.stop阻止事件的冒泡行为。

使用.prevent阻止事件的默认行为。

使用.self实现只有点击当前元素才会触发事件处理函数。

使用.capture实现捕获触发事件的机制,即从外部事件开始执行。

使用.once实现事件的触发次数为一次。

需要特别注意.stop和.self的区别:.stop是阻止除了自己之外所有的冒泡事件,而.self是控制自己被点击才会触发事件处理函数,阻止自己被冒泡所影响。


代码

<!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>事件修饰符</title>
    <script src="../lib/vue.js"></script>
    <style>
        .app{
            width: 200px;
            height: 200px;
            background: red;
        }
    </style>
</head>
<body>
    <!-- <div class="app" @click.capture="outClick"> -->
        <!-- 使用.capture实现捕获触发事件的机制,即从外部事件开始执行 -->
    <div class="app" @click.self="outClick">
        <!-- 使用.self实现只有点击当前元素才会触发事件处理函数-->
        <input type="button" value="按钮1" @click.stop="innerClick">
        <!-- 使用.stop阻止事件的冒泡行为 -->
        <input type="button" value="按钮2" @click.once="innerClick">
        <!-- 使用.once实现事件的触发次数为一次 -->
        <a href="https://www.baidu.com/" @click.prevent.stop="aClick">有事找百度</a>
        <!-- 使用.prevent阻止事件的默认行为 -->
    </div>
    <script>
        var vm = new Vue({
            el:".app",
            methods:{
                outClick(){
                    alert('我是外面的事件');
                },
                innerClick(){
                    alert('我是内部的事件');
                },
                aClick(){
                    alert('我是超链接的事件');
                }
            }
        })
    </script>
</body>
</html>


本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!

链接: https://shenqiku.cn/article/FLY_4649