• 【Vue】事件修饰符


    Vue中的事件修饰符:

      1.prevent:阻止默认事件(常用);

      2.stop:阻止事件冒泡(常用);

      3.once:事件只触发一次(常用);

      4.capture:使用事件的捕获模式;

      5.self:只有event.target是当前操作的元素时才触发事件;

      6.passive:事件的默认行为立即执行,无需等待事件回调执行完毕;

    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="UTF-8" />
            <title>事件修饰符</title>
            <!-- 引入Vue -->
            <script type="text/javascript" src="../js/vue.js"></script>
            <style>
                *{
                    margin-top: 20px;
                }
                .demo1{
                    height: 50px;
                    background-color: skyblue;
                }
                .box1{
                    padding: 5px;
                    background-color: skyblue;
                }
                .box2{
                    padding: 5px;
                    background-color: orange;
                }
                .list{
                     200px;
                    height: 200px;
                    background-color: peru;
                    overflow: auto;
                }
                li{
                    height: 100px;
                }
            </style>
        </head>
        <body>
            <!-- 准备好一个容器-->
            <div id="root">
                <!-- 阻止默认事件(常用) -->
                <a href="http://www.baidu.com" @click.prevent="showInfo">点我提示信息 不发生跳转行为</a>
     
                <!-- 阻止事件冒泡(常用) -->
                <div class="demo1" @click="showInfo">
                    <button @click.stop="showInfo">点我提示信息</button>
                    <!-- 修饰符可以连续写 -->
                    <!-- <a href="http://www.baidu.com" @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>
     
                <!-- 只有event.target是当前操作的元素时才触发事件; -->
                <div class="demo1" @click.self="showInfo">
                    <button @click="showInfo">点我提示信息</button>
                </div>
     
                <!-- 事件的默认行为立即执行,无需等待事件回调执行完毕; -->
                <ul @wheel.passive="demo" class="list">
                    <li>1</li>
                    <li>2</li>
                    <li>3</li>
                    <li>4</li>
                </ul>
     
            </div>
        </body>
     
        <script type="text/javascript">
            Vue.config.productionTip = false //阻止 vue 在启动时生成生产提示。
     
            new Vue({
                el:'#root',
                data:{
                },
                methods:{
                    showInfo(e){
                        alert('同学你好!')
                        // console.log(e.target)
                    },
                    showMsg(msg){
                        console.log(msg)
                    },
                    demo(){
                        for (let i = 0; i < 100000; i++) {
                            console.log('#')
                        }
                        console.log('累坏了')
                    }
                }
            })
        </script>
    </html>
  • 相关阅读:
    团队-科学计算器-设计文档
    团队-科学计算器-开发环境搭建过程
    《个人-GIT使用方法》
    结对-结对编项目作业名称-开发环境搭建过程
    结对编程项目作业-结对编项目设计文档
    阅读笔记,构建之法
    课程总结
    -阅读提问-3
    构建之法:现代软件工程-阅读笔记
    《科学计算机——环境搭建》
  • 原文地址:https://www.cnblogs.com/xjf125/p/16218375.html
Copyright © 2020-2023  润新知