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

基于类型的声明接收props

在 Vue 3 中,除了运行时声明这种常见方式,还可以通过基于类型的声明、解构赋值等方式来接收 props,下面为你详细介绍:

1. 基于类型的声明

这种方式借助 TypeScript 的类型系统来定义 props,具有类型检查和代码提示的优势,让代码更加健壮和易于维护。

示例代码
<template>
  <div>
    <p>用户名: {{ username }}</p>
    <p>是否活跃: {{ isActive }}</p>
  </div>
</template>

<script setup lang="ts">
// 定义 Props 接口来描述 props 的类型
interface Props {
  username: string;
  isActive?: boolean;
}

// 使用泛型指定 props 的类型
const props = defineProps<Props>();
</script>
代码解释
  • 定义了 Props 接口,其中 username 是必需的字符串类型,isActive 是可选的布尔类型。
  • defineProps<Props>() 通过泛型指定 props 的类型,从而完成 props 的接收。

2. 解构赋值

可以对 defineProps 返回的 props 对象进行解构赋值,方便在模板中直接使用 props。不过需要注意的是,直接解构会失去响应式,可使用 toRefs 来解决这个问题。

示例代码
<template>
  <div>
    <p>标题: {{ title }}</p>
    <p>描述: {{ description }}</p>
  </div>
</template>

<script setup>
import { toRefs } from 'vue';

// 运行时声明 props
const props = defineProps({
  title: {
    type: String,
    required: true
  },
  description: {
    type: String,
    default: '暂无描述'
  }
});

// 使用 toRefs 解构 props 以保持响应式
const { title, description } = toRefs(props);
</script>
代码解释
  • 首先使用运行时声明的方式定义 props
  • 然后使用 toRefs 对 props 进行解构,这样 title 和 description 就保持了响应式,当父组件传递的 props 发生变化时,子组件能够相应更新。

3. 结合 withDefaults 辅助函数

withDefaults 辅助函数可用于给基于类型声明的 props 设置默认值,增强了类型声明方式的灵活性。

示例代码
<template>
  <div>
    <p>颜色: {{ color }}</p>
    <p>大小: {{ size }}</p>
  </div>
</template>

<script setup lang="ts">
import { withDefaults } from 'vue';

interface Props {
  color: string;
  size?: number;
}

// 使用 withDefaults 为 props 设置默认值
const props = withDefaults(defineProps<Props>(), {
  size: 16
});
</script>
代码解释
  • 先定义 Props 接口来描述 props 的类型。
  • 使用 withDefaults 函数包裹 defineProps<Props>(),并传入一个对象来设置默认值,这里为 size 设置了默认值 16

相关文章:

  • 【深度学习】参数管理
  • 《平面几何强化训练题集》第2章5到9题
  • Linux:网络(网络编程基础)
  • GET请求、POST请求的区别
  • 案例分享 |高质量数据服务赋能智慧医疗3.0时代
  • 【嵌入式设备】滑动变阻器使用方式
  • eBPF初了解
  • 文章集锦-值得反复修订的文章
  • 我眼中的无服务架构:云时代的创新引擎
  • wordpress两个网站用同一个数据库的实现方法
  • 取反符号~
  • deepseek的regflow安装mac版本
  • 第十章:C++ 标准
  • 设备预测性维护指的是什么 设备预测性维护的基本功能
  • 【量化科普】Correlation,相关性
  • 多视图几何--恢复相机位姿/内参的几种方法
  • [数据结构]堆详解
  • 【网络协议详解】——路由策略技术(学习笔记)
  • 微前端之 Garfish.js 的基础使用教程和进阶配置
  • HAL库常用函数
  • 国内免费网站空间/seo优化是啥
  • 网站支付开发/购买友情链接
  • 做网站怎插入背景/西安楼市最新房价
  • 网站群建设的必要性/sem和seo有什么区别
  • 珠海华中建设工程有限公司网站/百度推广代理公司广州
  • 手机上如何做网站/seo海外推广