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

vue3的defineSlots()

这个主要是用于类型校验使用的,和 ts 一起对 slot 进行传递的值进行类型检查,主要在 具名作用域插槽 里面

先来看一下官网的说明,后面我会详细解释

接下来我们来看代码吧,我有一个文件夹,里面分别有一个 父组件one 和 一个 插槽子组件two

父组件 one 的代码:

<script setup lang="ts">
import two from './two.vue'

console.log('1111')
</script>
<template>
  <div>
    <h1>这是容器组件</h1>
    <two>
      <template v-slot:header="{ data, data1, data2 }">
        <h3>{{ data }}</h3>
        <h3>{{ data1 }}</h3>
        <h3>{{ data2 }}</h3>
      </template>
    </two>
  </div>
</template>

<style lang="less" scoped></style>

插槽子组件 two 的代码:

<script setup lang="ts">
import { ref } from 'vue'
const data = ref('123')
const data1 = ref('456')
const data2 = ref(['789'])
</script>
<template>
  <div>
    <h2>这是有位置的组件</h2>
    <div>header</div>
    <slot name="header" :data="data" :data1="data1" :data2="data2"></slot>
    <div>default</div>
    <slot></slot>
    <div>footer</div>
    <slot name="footer"></slot>
  </div>
</template>

<style lang="less" scoped></style>

这是运行之后的页面

上述代码在 vscode 里面并没有任何报错或者提醒,说明代码是正常的,但是 假如我们在 插槽子组件中 使用了 defineSlots()  对 slot 的属性进行标注,就会有提示

标注之后的 插槽子组件 two 代码:

<script setup lang="ts">
import { ref } from 'vue'
const data = ref('123')
const data1 = ref('456')
const data2 = ref(['789'])

defineSlots<{
  // 表示插槽名为 header 的插槽,接收的 data,data1,data2 属性类型为 string
  header(props: { data: string; data1: string; data2: string }): any
  default(): any
  footer(): any
}>()
</script>
<template>
  <div>
    <h2>这是有位置的组件</h2>
    <div>header</div>
    <!-- 但是我这里传过去的 data2 类型是 数组 -->
    <slot name="header" :data="data" :data1="data1" :data2="data2"></slot>
    <div>default</div>
    <slot></slot>
    <div>footer</div>
    <slot name="footer"></slot>
  </div>
</template>

<style lang="less" scoped></style>

vscode 进行的提示:


http://www.kler.cn/a/378031.html

相关文章:

  • Prim算法与Dijstra算法
  • 力扣排序350题 两个元组的交集2
  • flutter ios ffi 调试 .a文件 debug可以 release 不行
  • 银行金融知识竞赛活动策划方案
  • 新能源汽车空调压缩机:科技驱动的冷暖核心
  • openGauss数据库-头歌实验1-3 创建和管理模式
  • Docker篇(容器的备份与迁移)
  • 使用 JWT 实现 .NET 应用的授权与鉴权
  • 探索Python新境界:Buzhug库的神秘面纱
  • 第k个排列
  • 热key总结
  • AutoBench-V:一个专为 大型视觉语言模型基准测试而设计的全自动框架
  • 【Python实战】-- csv数据汇总
  • 12-Docker发布微服务
  • 推荐一款功能强大的数据库开发管理工具:SQLite Expert Pro
  • 数据库管理-第256期 Oracle DB 23.6新特性一览(20241031)
  • 使用 Faster Whisper 和 Gradio 实现实时语音转文字
  • Kafka相关知识点(下)
  • 一篇文章入门傅里叶变换
  • 道品智能科技与系统集成:迈向未来的科技之路
  • metasploit/modules/exploits 有哪些模块,以及具体使用案例
  • django自动创建的表
  • 创建 PostgreSQL 函数案例
  • 动态规划应该如何学习?
  • OpenSSL:生成 DER 格式的 RSA 密钥对
  • 多线程之间的通讯