vue2.x self capture事件修饰符学习

文章参考

  1. https://cn.vuejs.org/v2/guide/events.html#事件修饰符
    https://cn.vuejs.org/v2/guide/events.html#%E4%BA%8B%E4%BB%B6%E4%BF%AE%E9%A5%B0%E7%AC%A6

问题描述:

今天在写self Demo的时候,使用的大的div套小的div,在外层div中定义了self方法,发现怎么点击都生效,跟不使用self就没有区别,感觉有点模糊了,因此查看了相关资料,自己总结了一下

概念解释

  1. 当在 event.target 是当前元素自身时触发处理函数
  2. 即事件不是从内部元素触发的(不是捕获或者冒泡获取)
<div v-on:click.self="doThat">...</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="./js/vue.js"></script>
</head>
<style>
.bigbox{
    height: 200px;
    width: 200px;
    background: red;
}

.middlebox{
    height: 150px;
    width: 150px;
    background: blue;
}

.littlebox{
    height: 100px;
    width: 100px;
    background: green;
}


</style>
<body>
    <div id="app">
        <div class="bigbox" @click='bigAction'>
            <div class="middlebox" @click.self='middleAction()'>
                <div class="littlebox" @click='littleActionDefault()'>

                </div>
            </div>
        </div>
        <hr/>
        <div class="bigbox" @click.capture='bigAction'>
            <div class="middlebox" @click.capture.self='middleAction()'>
                <div class="littlebox" @click.capture='littleActionDefault()'>

                </div>
            </div>
        </div>
    </div>
</body>
<script> 
var app = new Vue({
    // 指明Vue的控制节点(控制范围)
    el: '#app',
    // 定义一个方法,返回一个JSON 数据
    data: function () {
        return {
            username: '优就业'
        }
    },
    methods: {
        bigAction: function (){
            console.log('bigAction');
        },
        middleAction: function () {
            console.log('middleAction');
        },
        littleActionDefault: function (){
            console.log('littleAction');
        }
    }
})
</script>
</html>

案例解析

  1. 浏览器默认执行的是“冒泡事件”
  2. 如果想执行“捕获事件”,则需要 .capture 修饰; @click.capture.self='middleAction()'
  3. 如果点击最小的div, 中间div事件是使用 self修饰,不管是捕获还是冒泡事件都被接收到了,但是中间div的事件不被执行
  4. 直接点击中间的.self事件才会被执行,即满足上面的原则,event.target 是当前元素自身时触发的,并且事件处理不接受冒泡和捕获
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值