vue事假机制都有哪些

Vue 的事件机制主要包含以下几种类型和方式,可以分为组件内部事件、父子组件通信事件、原生 DOM 事件封装、修饰符增强等,下面详细分类介绍:


一、DOM 事件绑定(最基础的事件)

使用 v-on(或简写 @)指令绑定原生 DOM 事件。

ini 复制代码
<button @click="handleClick">点击我</button>

二、自定义事件(组件通信)

1. 子组件通过 $emit 向父组件传递事件

子组件中:

xml 复制代码
<template>
  <button @click="$emit('custom-event', data)">发送事件</button>
</template>

父组件中:

ini 复制代码
<ChildComponent @custom-event="handleCustomEvent" />

2. 使用 v-model 进行双向绑定(语法糖)

Vue3 中可以绑定自定义 modelValueupdate:modelValue

子组件:

xml 复制代码
<template>
  <input :value="modelValue" @input="$emit('update:modelValue', $event.target.value)" />
</template>
<script>
export default {
  props: ['modelValue']
}
</script>

父组件:

ini 复制代码
<ChildComponent v-model="inputValue" />

三、事件修饰符

Vue 为事件添加了很多修饰符,用于增强行为:

  • .stop:阻止事件冒泡
  • .prevent:阻止默认行为
  • .capture:使用事件捕获模式
  • .self:只有事件是从绑定元素本身触发才触发
  • .once:事件只触发一次
  • .passive:使用被动监听器,适合滚动性能优化
arduino 复制代码
<button @click.stop.prevent="handleClick">点我</button>

四、键盘事件修饰符

ini 复制代码
<input @keyup.enter="submit" />

还支持 .esc, .tab, .delete, .arrow-up, .space 等等。


五、事件代理(原生方式)

在 Vue 中仍然可以使用事件代理:

ruby 复制代码
<ul @click="handleListClick">
  <li v-for="item in list" :key="item.id" :data-id="item.id">{{ item.name }}</li>
</ul>

六、 <math xmlns="http://www.w3.org/1998/Math/MathML"> o n / on / </math>on/off / $emit(Vue2 中的全局事件总线)

Vue2 可以通过事件总线实现跨组件通信:

php 复制代码
// event-bus.js
export const EventBus = new Vue();

// 发送事件
EventBus.$emit('someEvent', data);

// 接收事件
EventBus.$on('someEvent', data => { ... });

// 移除事件
EventBus.$off('someEvent');

⚠️ Vue3 中已经废弃 $on / $off / $emit,推荐使用 mittemitter 等库替代。


七、Vue3 中的事件通信方式

Vue3 推荐使用以下方式进行事件通信:

  • defineEmits()(组合式 API)
  • mitt 第三方事件库
  • provide/inject
  • PiniaVuex 状态管理
  • emits 选项配合 defineProps
ini 复制代码
// 子组件
const emit = defineEmits(['save']);
emit('save', payload);

八、自定义指令事件

Vue 允许你通过自定义指令实现特殊事件处理逻辑:

javascript 复制代码
app.directive('click-outside', {
  mounted(el, binding) {
    document.addEventListener('click', (e) => {
      if (!el.contains(e.target)) {
        binding.value(e)
      }
    });
  }
});

需要我帮你整理一个"Vue 事件机制脑图"或"快速参考表"吗?

相关推荐
Moment4 分钟前
小米不仅造车,还造模型?309B参数全开源,深度思考完胜DeepSeek 🐒🐒🐒
前端·人工智能·后端
苏打水com7 分钟前
第十六篇:Day46-48 前端安全进阶——从“漏洞防范”到“安全体系”(对标职场“攻防实战”需求)
前端·javascript·css·vue.js·html
5C249 分钟前
从思想到实践:前端工程化体系与 Webpack 构建架构深度解析
前端·前端工程化
咕噜企业分发小米15 分钟前
如何平衡服务器内存使用率和系统稳定性?
java·服务器·前端
前端无涯15 分钟前
react组件(2)---State 与生命周期
前端·react.js
GoldenPlayer16 分钟前
Web-Tech:CORS的触发机制
前端
AY呀17 分钟前
Vite:现代前端构建工具的革命与实战指南
前端·vue.js·vite
爬山算法17 分钟前
Netty(13)Netty中的事件和回调机制
java·前端·算法
重铸码农荣光18 分钟前
用AI把猫主子变成冰球猛将?我搞了个“宠物拟人化”神器,结果……它真敢打!
vue.js·低代码·coze
前端无涯22 分钟前
react组件(3)---组件间的通信
前端·react.js