【Vue3】组件通信之props

【Vue3】组件通信之props

背景

随着年龄的增长,很多曾经烂熟于心的技术原理已被岁月摩擦得愈发模糊起来,技术出身的人总是很难放下一些执念,遂将这些知识整理成文,以纪念曾经努力学习奋斗的日子。本文内容并非完全原创,大多是参考其他文章资料整理所得,感谢每位技术人的开源精神。

简介

本文介绍 Vue3 中如何使用 props 实现组件间通信,即组件间相互传数据。

Vue3 中组件间通信包括:

  • 父组件向子组件传数据,实现方案有:
    • props
    • v-model
    • $refs
    • 默认插槽 / 具名插槽
  • 子组件向父组件传数据
    • props
    • v-model
    • $parent
    • 自定义事件
    • 作用域插槽
  • 父组件与子组件的子组件互传数据,即与孙子组件互传数据
    • $attrs
    • provider & inject
  • 任意组件间传数据
    • mitt
    • Pinia

开发环境

分类 名称 版本
操作系统 Windows Windows 11
IDE Visual Studio Code 1.91.1

开发步骤及源码

1> 创建 Vue3 工程,参考:【Vue3】工程创建及目录说明

2> 删除 src 目录下 assetscomponents 目录。

3> 修改 src 目录下 main.ts

import { createApp } from 'vue'
import App from './App.vue'

createApp(App).mount('#app')

4> 定义子组件,接收来自父组件的数据。

<template>
    <div class="cont
### Vue3 中使用 Props 实现组件通信的方法 在 Vue3 中,`props` 是一种用于父组件向子组件传递数据的有效机制。当定义一个子组件时,可以指定它接收哪些 `props`,以及这些属性的数据类型和默认值。 #### 定义并验证 Prop 类型 为了确保传入的数据符合预期,在创建子组件时可通过声明 prop 的类型来进行基本的验证[^2]: ```javascript // 子组件 ChildComponent.vue export default { props: { message: String, // 只接受字符串类型的值作为message参数 count: Number, isActive: Boolean, items: Array, config: Object, callback: Function, customEvent: Symbol } } ``` #### 设置 Prop 默认值 对于某些可选性的配置项,可以在不提供具体数值的情况下让其采用预设好的缺省状态。这有助于减少不必要的错误,并提高代码健壮性[^4]: ```javascript // 子组件 DefaultPropsExample.vue export default { props: { title: { type: String, default: &#39;Default Title&#39; }, description: { type: String, required: false, default: () => &#39;&#39; } } }; ``` #### 父级到子级的数据流动 下面是一个简单的例子展示了如何利用 `props` 来完成从父组件到子组件的信息传输过程[^1]: ```html <!-- ParentComponent.vue --> <template> <div class="parent"> <!-- 向子组件传递名为 "greetingMessage" 的prop --> <child-component :greeting-message="msg"></child-component> </div> </template> <script setup> import { ref } from &#39;vue&#39;; const msg = ref(&#39;Hello from parent!&#39;); </script> ``` ```html <!-- ChildComponent.vue --> <template> <p>{{ greetingMessage }}</p> <!-- 显示来自父组件的消息 --> </template> <script setup> defineProps({ greetingMessage: String }); </script> ``` 在这个案例里,父组件通过绑定带有冒号 (`:`) 前缀的自定义标签属性来发送消息给子组件;而子组件则负责接收并通过模板语法将其渲染出来。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

又言又语

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值