【Vue3】Props的使用详解

本文详细介绍了Vue3中Props的使用,包括其基本用法、类型推断、默认值设置以及优缺点。重点讲解了如何通过defineProps从父组件向子组件传递数据并确保组件间的有效通信。
摘要由CSDN通过智能技术生成

💗💗💗欢迎来到我的博客,你将找到有关如何使用技术解决问题的文章,也会找到某个技术的学习路线。无论你是何种职业,我都希望我的博客对你有所帮助。最后不要忘记订阅我的博客以获取最新文章,也欢迎在文章下方留下你的评论和反馈。我期待着与你分享知识、互相学习和建立一个积极的社区。谢谢你的光临,让我们一起踏上这个知识之旅!
请添加图片描述

🍋介绍

在Vue3中,Props是一种用于从父组件向子组件传递数据的重要机制。Props可以让我们以声明式的方式将数据传递到子组件,使得组件之间的通信更加简单和可靠。本文将详细介绍Vue3中Props的用法

🍋回顾上节

我们首先在根组件中编写下面的数组

let personList = [
    {id:'a01',name:'大馒头',age:18},
    {id:'a02',name:'馒头',age:19},
    {id:'a03)d03',name:'小馒头',age:22}
  ]

但是这并不是响应式的数据,接下来我们引入reactive

  import {reactive} from 'vue'

但是这样子的话,我们如果在编写代码的时候打错了,也是不会产生错误的,这时候我们就需要用之前学到了接口那节了,Persons是自定义的

 import {type Persons} from '@/types'
  let personList = reactive<Persons>([
    {id:'asudfysafd01',name:'张三',age:18},
    {id:'asudfysafd02',name:'李四',age:20},
    {id:'asudfysaf)d03',name:'王五',age:22}
  ])

🍋props基本使用

接下来我们介绍本文的重点

我们首先在根组件定义一个a,同时我们定义一个list

<person a="馒头" list="personList" />

这时候我们别忘了在子组件的模版里写,要不然是不会有显示的

    <h2>{{ a }}</h2>
    <h2>{{ list }}</h2>

如果仅仅接受a和list的话

defineProps(['a','list'])

这样子运行后的界面如下图
在这里插入图片描述
但是这并不是我们想要的,我们想要的是Personlist的每一列数据,我们稍加修改

<person a="馒头" :list="personList" />

在这里插入图片描述
但是这样太丑了,我们在子组件中加点东西,下面的修改好的模版

v-for 是 Vue.js 提供的用来循环渲染列表的指令。通过 v-for,你可以遍历数组或对象,并为每个项或键值对执行相应的 DOM 操作

<template>
  <div class="person">
    <ul>
      <li v-for="i in list" :key="i.id">
        {{i.name}} - {{i.age}}
      </li>
    </ul>
</div>
 </template>

下图就是我们想要的展示了
在这里插入图片描述
但是只接受的话,根组件如果写错了,有可能发现不出来,并且在页面显示上会产生一定的问题,这就需要我们加一点限制了

  // 接收list + 限制类型
  defineProps<{list:Persons}>()

一旦出错会有提示
在这里插入图片描述
还有一种更高级的,设置了一个默认值,同时使用?用来限制必要性

  //  接收list + 限制类型 + 限制必要性 + 指定默认值
  withDefaults(defineProps<{list?:Persons}>(),{
    list:()=> [{id:'a04',name:'枣馒头',age:23}]
  })

注意:defineProps是一个用于定义组件 Props 的函数,它可以在组件的 setup 函数中直接使用,而无需导入

🍋优势

优点:

简洁明了: 使用 defineProps 可以在组件的 setup 函数中直接定义 Props,使得组件逻辑更加清晰和简洁

类型推断: 在使用 defineProps 定义 Props 时,可以根据指定的类型进行类型推断,提高了代码的健壮性和可读性

默认值和属性验证: 可以方便地指定 Props 的默认值和进行属性验证,确保组件的稳健性和可靠性

无需导入: 使用 defineProps 不需要导入任何其他模块,可以直接在组件中使用,减少了代码的复杂性

缺点:

仅适用于 setup 函数: defineProps 只能在组件的 setup 函数中使用,如果组件逻辑较为复杂,可能会导致 setup 函数过于臃肿

无法在模板中直接使用: 使用 defineProps 定义的 Props 不能直接在模板中使用,需要在 setup 函数中将其映射到返回的对象中才能在模板中使用

🍋总结

通过上述内容,我们可以看到在Vue3中如何使用Props来实现父子组件之间的数据传递,并掌握了Props的基本用法、属性验证、默认值设置等技巧。 Props是Vue3中非常重要的一个特性,熟练掌握Props的使用将有助于我们更好地构建可复用、灵活的组件

请添加图片描述

挑战与创造都是很痛苦的,但是很充实。

评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

小馒头学python

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

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

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

打赏作者

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

抵扣说明:

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

余额充值