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时 就是告诉浏览器 不用查询了我们没有阻止

相关推荐
乐兮创想 小林1 分钟前
企业官网移动端性能优化实战:从 Core Web Vitals 到图片/CDN/响应式的工程清单
前端·性能优化·网站建设·北京网站建设公司
疯狂SQL23 分钟前
JWT 在线解码、验签、生成一篇讲透:附前端实现、工具架构与在线体验地址
javascript·jwt·编解码·jwt测试
前端一小卒33 分钟前
不手写代码的第 30 天,我才明白前端这个岗位还剩什么
前端·javascript·ai编程
Ajie'Blog34 分钟前
Copilot Agent Tasks API 开放:AI 编程开始进入后台任务时代
服务器·前端·javascript·人工智能·copilot·ai编程
老毛肚1 小时前
jeecgboot vue TS & 模板化 04
前端·javascript·vue.js
晓13131 小时前
【Cocos Creator 2.x】篇——第二章 入门
javascript·游戏引擎
AI_零食2 小时前
鸿蒙PC Electron跨平台应用开发:24时区时间表应用详解
前端·华为·electron·开源·harmonyos·鸿蒙
Electrolux3 小时前
[onlyoffice-v9]纯前端怎么实现编辑预览office
前端·javascript·github
VidDown3 小时前
Webhook 调试器:让第三方回调“原形毕露”
java·开发语言·javascript·编辑器·postman
码云之上3 小时前
聊聊如何设计一个高效、稳定的 Node.js 接入层
前端·后端·node.js