【从零开始学习Vue|第八篇】深入组件——组件事件

1. 触发和监听事件

在组件的模板表达式中,可以直接使用 $emit 方法触发自定义事件 (例如:在 v-on 的处理函数中):

xml 复制代码
<!-- MyComponent -->
<button @click="$emit('someEvent')">Click Me</button>

父组件可以通过 v-on (缩写为 @) 来监听事件:

ini 复制代码
父组件
<MyComponent @some-event="callback" />

同样,组件的事件监听器也支持 .once 修饰符:

ini 复制代码
设置事件只触发一次
<MyComponent @some-event.once="callback" />

像组件与 prop 一样,事件的名字也提供了自动的格式转换。注意这里我们触发了一个以 camelCase 形式命名的事件,但在父组件中可以使用 kebab-case 形式来监听。

2. 事件参数

有时候我们会需要在触发事件时附带一个特定的值。举例来说,我们想要 <BlogPost> 组件来管理文本会缩放得多大。在这个场景下,我们可以给 $emit 提供一个额外的参数:

kotlin 复制代码
<button @click="$emit('increaseBy', 1)">
  Increase by 1
</button>

然后我们在父组件中监听事件,我们可以先简单写一个内联的箭头函数作为监听器,此函数会接收到事件附带的参数:

ini 复制代码
<MyButton @increase-by="(n) => count += n" />

或者,也可以用一个组件方法来作为事件处理函数:

ini 复制代码
<MyButton @increase-by="increaseCount" />

该方法也会接收到事件所传递的参数:

javascript 复制代码
function increaseCount(n) {
  count.value += n
}

案例如下:

xml 复制代码
<!-- 子组件 MyButton.vue -->
<template>
  <!-- 传递 1 给父组件 -->
  <button @click="$emit('increaseBy', 1)">+1</button>
  
  <!-- 也可以传递 5 -->
  <button @click="$emit('increaseBy', 5)">+5</button>
  
  <!-- 也可以传递 10 -->
  <button @click="$emit('increaseBy', 10)">+10</button>
</template>

<!-- 父组件 -->
<template>
  <MyButton @increase-by="(n) => count += n" />
  <p>当前计数:{{ count }}</p>
</template>

<script setup>
const count = ref(0)
</script>

3. 事件校验

xml 复制代码
<script setup>
const emit = defineEmits({
  // 没有校验
  click: null,

  // 校验 submit 事件
  submit: ({ email, password }) => {
    if (email && password) {
      return true
    } else {
      console.warn('Invalid submit event payload!')
      return false
    }
  }
})

function submitForm(email, password) {
  emit('submit', { email, password })
}
</script>
相关推荐
摸鱼小李上线了5 分钟前
vue项目页面添加水印实现方法
前端·javascript·vue.js
砍材农夫10 分钟前
物联网 基于netty构建mqtt协议规范(主题通配符订阅)
java·前端·javascript·物联网·netty
彩票管理中心秘书长14 分钟前
智能体状态指示:何时思考、何时调用工具、何时出错
前端·后端·程序员
彩票管理中心秘书长15 分钟前
React + TypeScript拆解一整套“AI 变现代码流程”
前端·后端·程序员
广州华水科技18 分钟前
单北斗GNSS变形监测在基础设施安全中的应用与维护
前端
码途漫谈20 分钟前
把前端组件做成一座小岛:Animal-Island-UI 的自然风 React 组件库拆解
前端·开源
星栈25 分钟前
Rust 全栈项目里,我写了一个不再重复造轮子的泛型表格组件
前端·前端框架·开源
008爬虫实战录26 分钟前
【码上爬】 题九:webpack调试 堆栈分析
前端·webpack·node.js
Maimai108081 小时前
React 多步骤表单工程化落地:从 Zod Schema、React Hook Form 到 Zustand 持久化
前端·javascript·react.js·前端框架·状态模式
程序员码歌1 小时前
我是怎么部署开源 AI 编程助手 OpenCode,并在两个真实场景使用起来的
前端·人工智能·后端