zoukankan      html  css  js  c++  java
  • vue修饰符capture和self

    capture

    .capture事件修饰符的作用添加事件侦听器时使用事件捕获模式

    即是给元素添加一个监听器,当元素发生冒泡时,先触发带有该修饰符的元素。若有多个该修饰符,则由外而内触发。

    就是谁有该事件修饰符,就先触发谁。(捕获阶段触发,从外向内,没有capture修饰符的,从内向外冒泡触发)

    <!DOCTYPE html>
    <html lang="en">
    <head>
    <meta charset="UTF-8">
    <title>.capture事件修饰符</title>
    <style type="text/css">
    * {
    margin: 0 auto;
    text-align: center;
    line-height: 40px;
    }
    div {
    100px;
    }
    #obj1 {
    background: deeppink;
    }
    #obj2 {
    background: pink;
    }
    #obj3 {
    background: hotpink;
    }
    #obj4 {
    background: #ff4225;
    }
    </style>
    <script src="https://cdn.bootcss.com/vue/2.4.2/vue.min.js"></script>
    </head>
    <body>
    <div id="content">
    <div id="obj1" v-on:click.capture="doc(event)">
    obj1
    <div id="obj2" v-on:click.capture="doc(event)">
    obj2
    <div id="obj3" v-on:click="doc(event)">
    obj3
    <div id="obj4" v-on:click="doc(event)">
    obj4
    <!--。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。点击obj4的时候,弹出的顺序为:obj1、obj2、obj4、obj3;
    由于1,2有修饰符,故而先触发事件,然后就是4本身触发,最后冒泡事件。
    -->
    </div>
    </div>
    </div>
    </div>
    </div>
    <script type="text/javascript">
    var content = new Vue({
    el: "#content",
    data: {
    id: ''
    },
    methods: {
    doc(event) {
    this.id = event.currentTarget.id;
    alert(this.id)
    }
    }
    })
    </script>
    </body>
    </html>

     self只当事件是从侦听器绑定的元素本身触发时才触发回调

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>.capture事件修饰符</title>
        <style type="text/css">
            * {
                margin: 0 auto;
                text-align: center;
                line-height: 40px;
            }
            div{
                200px;
            }
    
        </style>
        <script src="https://cdn.bootcss.com/vue/2.4.2/vue.min.js"></script>
    </head>
    <body>
    <div id="app">
       <div class="box1"  style="background: red;" @click.self="test1">
           box1
           <div class="box2" style="background: yellow;">
               box2
    <!--box3点击触发test3不会触发test1,如果去除self修饰符就会触发,也就是说加了self元素的事件,只有自身触发才会执行回调,不执行冒泡过来的事件-->
    <div class="box3" style="background: pink;" @click.self="test3">box3</div> </div> </div> </div> <script type="text/javascript"> new Vue({ el:'#app', data:{ }, methods:{ test1(){ console.log('box1'); } , test3(){ console.log('box3'); } } }) </script> </body> </html>
  • 相关阅读:
    js高程之作用域
    js继承的实现(原型/链、函数伪装)
    tween.js的API实践
    JavaScript高程第三版笔记(1-5章)
    flex布局使用方法简要汇总
    three.js中物体旋转实践之房门的打开与关闭
    遇见贵人的科学方法(通向财富自由学习笔记七)
    "活在未来" VS “活在当下”(通向财富自由学习笔记六)
    记CBS一次动人心魄的数据保卫战
    你的人生最重的枷锁是什么?(通向财富自由学习笔记五)
  • 原文地址:https://www.cnblogs.com/baixiaoxiao/p/11072163.html
Copyright © 2011-2022 走看看