vue3事件处理详解

一、事件绑定基础(v-on / @

1. 基本语法

javascript 复制代码
<button v-on:click="handleClick">点击</button>
<!-- 简写 -->
<button @click="handleClick">点击</button>
javascript 复制代码
<script setup lang="ts">
const handleClick = () => {
  console.log('clicked')
}
</script>

要点

  • @v-on: 的语法糖

  • Vue 3 中事件函数通常定义在 setup()<script setup>

  • 事件名默认是 DOM 原生事件


2. 内联事件表达式

javascript 复制代码
<button @click="count++">+</button>
<p>{{ count }}</p>
javascript 复制代码
const count = ref(0)

说明

  • 可直接写 JS 表达式

  • 适合简单逻辑,不建议写复杂业务


二、事件参数与 $event

1. 获取事件对象

javascript 复制代码
<button @click="handleClick">点击</button>
javascript 复制代码
const handleClick = (event: MouseEvent) => {
  console.log(event.target)
}

Vue 会自动注入 $event


2. 同时传自定义参数 + 事件对象

html 复制代码
<button @click="handleClick(1, $event)">点击</button>
javascript 复制代码
const handleClick = (id: number, event: MouseEvent) => {
  console.log(id, event)
}

三、事件修饰符(重点)

1. 阻止冒泡 / 默认行为

修饰符 作用
.stop event.stopPropagation()
.prevent event.preventDefault()
javascript 复制代码
<a href="#" @click.prevent>阻止默认</a>

<div @click="parent">
  <button @click.stop="child">子按钮</button>
</div>

2. 捕获、只触发一次

修饰符 作用
.capture 捕获阶段触发
.once 只执行一次
javascript 复制代码
<button @click.once="submit">提交</button>

3. 键盘事件修饰符

javascript 复制代码
<input @keyup.enter="submit" />
<input @keyup.esc="cancel" />

常用键:

  • .enter

  • .esc

  • .tab

  • .space

  • .delete

  • .up / down / left / right


4. 系统按键修饰符

javascript 复制代码
<button @click.ctrl="doSomething">Ctrl + Click</button>
<button @keyup.alt.enter="submit" />

支持:

  • .ctrl

  • .alt

  • .shift

  • .meta(Mac Command / Windows Win)


5. 鼠标按钮修饰符

javascript 复制代码
<button @click.left>左键</button>
<button @click.right.prevent>右键</button>
<button @click.middle>中键</button>

四、事件处理与 Composition API

1. setup 中事件绑定(推荐)

html 复制代码
<script setup lang="ts">
const handleSubmit = () => {
  console.log('submit')
}
</script>

<template>
  <button @click="handleSubmit">提交</button>
</template>

2. 使用 ref 操作 DOM 绑定事件(不推荐优先)

javascript 复制代码
<template>
  <button ref="btn">按钮</button>
</template>

<script setup lang="ts">
const btn = ref<HTMLButtonElement>()

onMounted(() => {
  btn.value?.addEventListener('click', () => {
    console.log('native click')
  })
})
</script>

建议

  • 优先使用 @click

  • 仅在第三方库或特殊场景操作 DOM


五、自定义事件(组件通信,核心)

1. 子组件触发事件(emit

javascript 复制代码
<!-- Child.vue -->
<script setup lang="ts">
const emit = defineEmits<{
  (e: 'update', value: number): void
}>()

const add = () => {
  emit('update', 1)
}
</script>

<template>
  <button @click="add">+1</button>
</template>

2. 父组件监听事件

javascript 复制代码
<Child @update="handleUpdate" />
javascript 复制代码
const handleUpdate = (val: number) => {
  console.log(val)
}

3. 事件命名规范(重要)

场景 推荐
组件事件 kebab-case
v-model update:modelValue
javascript 复制代码
emit('update:modelValue', newValue)

六、v-model 本质是事件

1. v-model 等价写法

javascript 复制代码
<Child v-model="value" />

等价于:

javascript 复制代码
<Child
  :modelValue="value"
  @update:modelValue="value = $event"
/>

2. 多个 v-model(Vue 3 特性)

html 复制代码
<Child v-model:title="title" v-model:visible="visible" />

子组件:

html 复制代码
emit('update:title', 'new title') emit('update:visible', true)

相关推荐
是梦终空4 小时前
计算机毕业设计263—基于Springboot+Vue的影视推荐和评分系统(源代码+数据库)
spring boot·vue·毕业设计·课程设计·协同过滤算法·影评系统·影视推荐系统
EstherNi5 小时前
小程序中,下拉多选的组件,有写死的三级下拉,样式需要修改
javascript·小程序·vue
青春男大1 天前
已有后端基础学习前端简单页面交互
前端·javascript·学习·typescript·vue
shejizuopin1 天前
基于Spring Boot的高校科研管理系统的设计与实现(毕业论文)
java·spring boot·vue·毕业设计·论文·毕业论文·高校科研管理系统的设计与实现
皮卡穆1 天前
Vue3 + Swiper.js 实现无缝轮播图组件
前端·javascript·vue
泰勒疯狂展开2 天前
Vue3研学-组件的生命周期
开发语言·前端·vue
千寻技术帮2 天前
10392_基于SpringBoot的大学迎新系统
mysql·vue·源码·springboot·代码·新生报到
总爱写点小BUG3 天前
VU-Icons:打造极致体验的 Vue3 & UniApp 双端 SVG 图标库
uni-app·vue·组件库·图标组件库
换日线°4 天前
微信小程序对接位置服务(腾讯、高德)完成路径规划
前端·微信小程序·vue
攻城狮7号5 天前
不懂代码也能造?TRAE+GLM-4.6 手把手教你搭心理咨询智能客服小程序
python·小程序·uni-app·vue·trae·glm我的编程搭子·glm-4.6