当前位置: 首页 > news >正文

vue3中接收props的两种写法

在 Vue 3 中,接收 props 有两种主要的写法,分别是运行时声明基于类型的声明。下面为你详细介绍这两种写法。

1. 运行时声明

运行时声明是 Vue 2 中就已经存在的方式,在 Vue 3 中依然可以使用。这种方式通过在组件中使用 defineProps 宏来定义 props,并且可以指定 props 的类型、默认值和验证规则。

示例代码
<template>
  <div>
    <p>Name: {{ name }}</p>
    <p>Age: {{ age }}</p>
  </div>
</template>

<script setup>
// 使用运行时声明接收props
const props = defineProps({
  name: {
    type: String,
    required: true
  },
  age: {
    type: Number,
    default: 18
  }
});
</script>
代码解释
  • defineProps 是一个宏,用于定义组件的 props
  • name 和 age 是定义的两个 props
    • name 是一个必需的字符串类型的 prop
    • age 是一个可选的数字类型的 prop,默认值为 18

2. 基于类型的声明

基于类型的声明是 Vue 3 新增的特性,它利用 TypeScript 的类型系统来定义 props。这种方式更加简洁,并且可以提供更好的类型检查。

示例代码
<template>
  <div>
    <p>Name: {{ name }}</p>
    <p>Age: {{ age }}</p>
  </div>
</template>

<script setup lang="ts">
// 使用基于类型的声明接收props
interface Props {
  name: string;
  age?: number;
}

const props = defineProps<Props>();
</script>
代码解释
  • 首先定义了一个 Props 接口,用于描述 props 的类型。
  • name 是一个必需的字符串类型的 prop
  • age 是一个可选的数字类型的 prop
  • defineProps<Props>() 使用泛型来指定 props 的类型。

两种写法的对比

  • 运行时声明:适用于不使用 TypeScript 的项目,或者需要定义复杂的验证规则和默认值的场景。
  • 基于类型的声明:适用于使用 TypeScript 的项目,它可以提供更好的类型检查和代码提示。

使用组件

无论使用哪种方式声明 props,使用组件时传递 props 的方式是相同的。

<template>
  <MyComponent name="John" age="25" />
</template>

<script setup>
import MyComponent from './MyComponent.vue';
</script>

以上就是 Vue 3 中接收 props 的两种主要写法。

相关文章:

  • Liunx系统 : 进程间通信【IPC-Shm共享内存】
  • 基于PyQt5的全能图片处理工具开发实践
  • 本地缓存和分布式缓存
  • C++ 编程指南26 - 尽量缩短在临界区(critical section)内的执行时间
  • 用友U9二次开发-问题记录
  • 理解知识如何在大型Vision-Language Models 中演化
  • 从基础到实践(十三):无源晶振和有源晶振的应用指南
  • 从 Web2 到 Web3:互联网发展的重要转折
  • 电脑的常见问题的原因+解决方法
  • Anaconda中虚拟环境安装g++和gcc相同版本
  • Centos 7 修改语言和输入源为中文+修改终端快捷键复制为Ctrl+C、粘贴为Ctrl+V
  • 腾讯云低代码开发应用
  • Mentalab Explore 在低密度 EEG 系统中的创新应用
  • 封装哈希表实现unordered_map和unordered_set
  • nginx优化
  • 工作记录 2016-12-28
  • 【10】单片机时间和速度的起源:指令周期与晶振频率
  • EOB Payment的一些例子
  • Http和Https的区别
  • ADSP21569 集成开发map映射功能整理
  • 沧州好的做网站的公司/企业网站优化工具
  • 个人网站建设公司/seo网站优化培训怎么做
  • 甘肃 网站建设/怎样做自己的网站
  • wordpress更多的模板/seo的优化方向
  • 小程序代运营/荆门网站seo
  • 北京公司网站制作要多少钱/浏览器谷歌手机版下载