vue学习(10)事件修饰符

简介: vue学习(10)事件修饰符
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>事件处理</title>
    <style>
        * {
   
            margin-top: 20px;
        }
        .demo1 {
   
            height:50px;
            background: skyblue;
        }
        .box1 {
   
            padding:5px;
            background: skyblue;
        }
        .box2 {
   
            padding:5px;
            background: orange;
        }
    </style>
</head>

<body>
    <div id="root">
        <h2>欢迎来学习{
   {
   name}}</h2>
        <!-- 阻止默认事件 -->
        <a href="https://www.jianshu.com/writer#/notebooks/51864668/notes/98452516/preview" @click.prevent="showInfo">点我提示信息</a>
        <!-- 阻止冒泡事件 -->
        <div class="demo1" @click="showInfo">
            <button @click.stop="showInfo">点我提示信息</button>
        </div>
        <!-- 事件修饰符连续写 -->
        <div class="demo1" @click="showInfo">
            <a href="https://www.jianshu.com/writer#/notebooks/51864668/notes/98452516/preview" @click.prevent.stop="showInfo">点我提示信息</a>
        </div>
        <!-- 事件只触发一次 -->
        <button @click.once="showInfo">点我提示信息</button>
        <!-- 事件捕获阶段处理事件 -->
        <div class="box1" @click.capture="showMsg(1)">
            div1
            <div class="box2" @click="showMsg(2)">
                div2
            </div>
        </div>
        <!-- self只有event.target是当前操作元素的时候才执行事件 -->
        <div class="demo1" @click.self="showInfo">
            <button @click="showInfo">点我提示信息</button>
        </div>
    </div>
    <script src="../js/vue.js"></script>
    <script type="text/javascript">
        Vue.config.productionTip = false;
        new Vue({
   
            el: '#root',
            data: {
   
                name: 'vue'
            },
            methods: {
   
                showInfo() {
   
                    alert('同学你好');
                },
                showMsg(msg){
   
                    console.log(msg);
                }
            }
        })
    </script>
</body>

</html>

知识点:
vue事件修饰符:
1.prevent:阻止默认事件。(常用)
2.stop:阻止冒泡事件。(常用)
3.once:事件只触发一次。(常用)
4.capture:使用事件的捕获模式。默认是在事件流的冒泡阶段处理事件。
5.self:只有event.target是当前操作的元素时才触发。其实效果和冒泡类似,只是设置在不同的元素上。
6.passive:事件的默认行为立即执行,无需等待事件回调执行完毕。
7.修饰符可以连续写。

目录
相关文章
|
1天前
|
JavaScript 前端开发 网络架构
vue 路由器history和hash工作模式
vue 路由器history和hash工作模式
|
2天前
|
JSON JavaScript 前端开发
vue尚品汇商城项目-day00【项目介绍:此项目是基于vue2的前台电商项目和后台管理系统】
vue尚品汇商城项目-day00【项目介绍:此项目是基于vue2的前台电商项目和后台管理系统】
10 1
|
3天前
|
JavaScript 前端开发
vue尚品汇商城项目-day01【3.项目路由的分析】
vue尚品汇商城项目-day01【3.项目路由的分析】
11 1
|
2天前
|
JSON 缓存 JavaScript
vue尚品汇商城项目-day01【1.vue-cli脚手架初始化项目生成文件的介绍】
vue尚品汇商城项目-day01【1.vue-cli脚手架初始化项目生成文件的介绍】
10 0
|
2天前
|
JavaScript
vue尚品汇商城项目-day01【2.vue-cli脚手架初始化项目的其他配置】
vue尚品汇商城项目-day01【2.vue-cli脚手架初始化项目的其他配置】
9 0
|
3天前
|
JavaScript 数据格式
vue3 + Ant design vue formItem 无法使用嵌套的form表单校验
vue3 + Ant design vue formItem 无法使用嵌套的form表单校验
22 1
|
3天前
|
JavaScript 前端开发
vue尚品汇商城项目-day01【4.完成非路由组件Header与Footer业务】
vue尚品汇商城项目-day01【4.完成非路由组件Header与Footer业务】
12 2
|
3天前
|
JavaScript 前端开发 数据安全/隐私保护
vue尚品汇商城项目-day01【5.路由组件的搭建】
vue尚品汇商城项目-day01【5.路由组件的搭建】
9 0
vue尚品汇商城项目-day01【5.路由组件的搭建】
|
4天前
|
JavaScript 索引
vue尚品汇商城项目-day04【25.面包屑处理关键字】
vue尚品汇商城项目-day04【25.面包屑处理关键字】
20 1
|
4天前
|
JavaScript 前端开发 API
vue尚品汇商城项目-day04【28.详情页面Detail】
vue尚品汇商城项目-day04【28.详情页面Detail】
13 1