Vue事件修饰符

一,事件修饰符有哪些

|----------|-------------------------|
| .stop | 阻止事件冒泡 |
| .prevent | 阻止标签的默认行为 |
| .once | 只触发一次,加上once之后prevent失效 |
| .capture | 捕获冒泡 |
| .self | 将事件绑定到自身,只有自身才能触发 |
| .passive | 不阻止事件的默认行为 |

二,如何使用

在方法或者函数后面直接.修饰符就行

比如

html 复制代码
<button @click.stop=""></button>

三,案例演示

一 stop 用于点击子元素时 阻止父元素的触发

html 复制代码
<template>
  <h3>测试</h3>
  <div @click="fu">
    <div @click.stop="zi">
      <button>提交</button>
    </div>
  </div>
</template>

<script >
export default{
  data(){
    return{
      msg:0
    },
    methods,{

    }
  }
}
</script>

2.prevent 阻止标签的默认行为 将不会跳转到/www.baidu.com页面

html 复制代码
<a href="https://www.baidu.com" @click.prevent="aClick">百度一下</a>

3.once: 加上once修饰符之后事件只触发一次,但是once不影响事件的冒泡,上层事件仍然会触发,并且加上once的事件prevent会失效

html 复制代码
<div id="app" @click="divClick">
        <div id="aa" @click="aaClick">
            <button @click.once="btnClick">按钮</button>
        </div>
    </div>

4.capture: 优先执行被capture所修饰的方法或者函数

html 复制代码
    <div id="app" @click="divClick">
        <div id="aa" @click.capture="aaClick">
            <button @click="btnClick">按钮</button>
        </div>
    </div>

先执行aaClick之后执行btnClick最后执行divClick

5.self: 被点击时 只有自身的方法或者函数被触发 但不影响事件冒泡

html 复制代码
 <div id="app" @click="divClick">
        <div id="aa" @click.self="aaClick">
            <button @click="btnClick">按钮</button>
        </div>
    </div>

点击按钮结果就是:执行btnClick和divClick,跳过aaClick;

点击中间层aa结果:执行aaClick和divClick,他也不影响事件冒泡

6.passive:用来告诉浏览器你不想阻止的事件的默认行为 当我们运行项目时浏览器会自动查询 有没有阻止事件 当我们加上passive时 就是告诉浏览器 不用查询了我们没有阻止

相关推荐
小Tomkk几秒前
⭐️ StarRocks Web 使用介绍与实战指南
前端·ffmpeg
计算机学姐3 分钟前
基于SpringBoot的汽车租赁系统【个性化推荐算法+数据可视化统计】
java·vue.js·spring boot·后端·spring·汽车·推荐算法
不一样的少年_4 分钟前
产品催: 1 天优化 Vue 官网 SEO?我用这个插件半天搞定(不重构 Nuxt)
前端·javascript·vue.js
-dcr6 分钟前
50.智能体
前端·javascript·人工智能·ai·easyui
BingoGo7 分钟前
免费可商用商业级管理后台 CatchAdmin V5 正式发布 插件化与开发效率的全面提升
vue.js·后端·php
行者9615 分钟前
Flutter跨平台开发适配OpenHarmony:进度条组件的深度实践
开发语言·前端·flutter·harmonyos·鸿蒙
云和数据.ChenGuang16 分钟前
Uvicorn 是 **Python 生态中用于运行异步 Web 应用的 ASGI 服务器**
服务器·前端·人工智能·python·机器学习
IT_陈寒18 分钟前
SpringBoot 3.0实战:这5个新特性让你的开发效率提升50%
前端·人工智能·后端
哈__22 分钟前
React Native 鸿蒙跨平台开发:LayoutAnimation 实现鸿蒙端页面切换的淡入淡出过渡动画
javascript·react native·react.js
遗憾随她而去.26 分钟前
Webpack 面试题
前端·webpack·node.js