Vue2.0 Vue事件处理修饰符(v-on.)

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title>事件处理</title>
    </head>
    <body>
        <div id="root">
            欢迎{{name}}
            <a href="https://www.bilibili.com" @click="showInfo">点我</a>
        </div>
    </body>
    <script src="indexJS.js"></script>
</html>
Vue.config.productionTip=false

new Vue({
    el: '#root',
    data() {
        return {
            name: '陈天羽'
        }
    },
    methods: {
        showInfo(){
            alert('同学你好')
        }
    },
})

弹窗后就跳走了,我不想让它跳走
跳走是<a>标签的默认行为

methods: {
        showInfo(e){
            e.preventDefault();
            alert('同学你好')
        }
    },

e.preventDefault();原意是event.preventDefault();来阻止默认行为;还可以用另一种方法阻止掉这个默认事件

<a href="https://www.bilibili.com" @click.prevent="showInfo">prevent按键</a>

那vue给我准备了几个修饰符
Vue中的事件修饰符
1.prevent: 阻止默认事件(常用);
2.stop: 阻止事件冒泡(常用);
3.once: 事件只触发一次(常用);
4.capture: 使用事件的捕获模式;
5.self: 只有event.target是当前操作元素时才触发;
6.passive: 事件的默认行为立刻执行,无需等待事件回调执行完成;

stop: 阻止事件冒泡

<div class="demo1" @click="showInfo1">
    <button @click="showInfo1">点我</button>
</div>

点击了按钮弹窗出现了俩次(这就是冒泡(点击了按键冒泡到了div的身上))
阻止这个冒泡可以写一个配置方法

showInfo1(e){
    e.stopPropagation();
    alert('同学你好')
}

还可以在html:

<div class="demo1" @click="showInfo1">
    <button @click.stop="showInfo1">stop按键</button>
</div>

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

你点了一次弹窗,之后你不希望在有这个了

capture: 使用事件的捕获模式

<div>
    div1
    <div>
        div2
    </div>
</div>

先进行事件捕获,再是事件冒泡

捕获阶段是由外往内的;随后触发的是冒泡阶段,是有内往外的
不想再冒泡的时候处理
我想在捕获阶段就开始处理事件,就可以

<div @click.capture="showInfo2(1)">
    div1
    <div @click="showInfo2(2)">div2</div>
</div>

对于div1来说事件在捕获阶段就已经开始了

passive: 事件的默认行为立刻执行,无需等待事件回调执行完成

关于滚动是有俩个单词的

  • scroll
  • wheel:鼠标滚动轮的滚动
    这俩的区别是wheel即便是滚动到最下面在滚动依然会触发;
    scroll滚动到最下面怎么滚动都不会触发
<ul @wheel.passive="demo1" class="list">
                <li>1</li>
                <li>2</li>
                <li>3</li>
                <li>4</li>
            </ul>

优先响应滚动

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

结城明日奈是我老婆

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值