Vue3 组件通信本质:Props 下发,Emits 回传

辅助理解 Props + Emits

官网原文地址:

Props互动教程

https://cn.vuejs.org/tutorial/#step-12

Emits互动教程

https://cn.vuejs.org/tutorial/#step-13


如下代码的大致流程

TypeScript 复制代码
子组件点击按钮
   ↓
emit('increment', i)
   ↓
父组件 @increment 接收
   ↓
handleIncrement(val)
   ↓
父组件执行逻辑

App.vue

TypeScript 复制代码
<script setup>
import { ref } from 'vue'
import ChildComp from './ChildComp.vue'

const greeting = ref('Hello from parent')

const handleIncrement = (val) => {
  console.log('子组件传回来的值:', val)
}
</script>

<template>
  <!-- 父组件可以使用 v-on 简写@ 监听子组件触发的事件 -->
  <ChildComp :msg="greeting" @increment="handleIncrement"/>
</template>

ChildComp.vue

TypeScript 复制代码
<script setup>

// 声明触发的事件
const emit = defineEmits(['increment'])

// defineProps() 是一个编译时宏,并不需要导入
const props = defineProps({
  msg: String
})

let i = 0
const increment123 = () => {
  // 带参数触发
  emit('increment', i++)
}
</script>

<template>
  <h2>{{ msg || 'No props passed yet' }}</h2>
  <button @click="increment123">子组件点我</button>
</template>

💡 关键理解(非常重要)

❌ 错误思维

子组件去"改父组件逻辑"

✅ 正确思维

子组件只负责"发信号"


最终你要形成的"脑内模型"

TypeScript 复制代码
数据在父组件(ref)
        ↓
props 传给子组件
        ↓
子组件不能改 props
        ↓
只能 emit 通知父组件改
        ↓
父组件更新 → props 再下发

++仅供学习参考++

相关推荐
canonical_entropy1 小时前
下一代低代码渲染框架 nop-chaos-flux 的设计原则
前端·低代码·前端框架
东方小月1 小时前
5分钟搞懂Harness Engineering(驾驭工程):从提示词到AI Agent的进化之路
前端·后端·架构
我叫黑大帅1 小时前
为什么需要 @types/react?解决“无法找到模块 react 的声明文件”报错
前端·javascript·面试
之歆1 小时前
DAY_21JavaScript 深度解析:数组(Array)与函数(Function)(一)
前端·javascript
XinZong2 小时前
【AI社交】基于OpenClaw自研轻量化AI社交平台实战
前端
Le_ee2 小时前
ctfweb:php/php短标签/.haccess+图片马/XXE
开发语言·前端·php
爱上好庆祝3 小时前
学习js的第七天(wed APIs的开始)
前端·javascript·css·学习·html·css3
KaMeidebaby3 小时前
卡梅德生物技术快报|冻干工艺开发:注射用心肌肽全流程参数优化与工程化方案
前端·其他·百度·新浪微博
ooseabiscuit4 小时前
Laravel6.x核心优化与特性全解析
android·开发语言·javascript
哆啦A梦15884 小时前
20, Springboot3+vue3实现前台轮播图和详情页的设计
javascript·数据库·spring boot·mybatis·vue3