vue3中的父子组件传递slot的方式

缘起

目前的 vue3 工程,有处相似的地方,上面是一个 a-step 组件,下面是一个 vxetable 的组件,目前有好几处都是各自复制这两个组件,进行各自的处理。所以就要把这处,改成一个组件,供小伙伴们使用。

分析

大组件套了两个小组件是没有问题的,但是卡在一个地方,vxetable 的组件,可能会使用多个具名插槽。所以意思就是说,在父组件的具名插槽,需要原样传递给子组件,然后子组件里面需要把这个插槽,再原样传递给 vxetable 的组件,最终就达到这么一个效果。

实现

父组件

javascript 复制代码
<parentCom title="标题名字" :statusConfig="statusConfig" :tableConfig="tableConfig">

    <template #slotName="{ row }">

        <span v-if="row.name">{{ row.name }}</span>

        <a class="a-link" v-else>选择</a>

    </template>

    <template #slotName2="{ row }">

        <span v-if="row.name2">{{ row.name2 }}</span>

        <a class="a-link" v-else>选择</a>

    </template>

</parentCom>

子组件

html 复制代码
<div class="process-box">

  <div class="title">

    <span class="left">{{ props.title }}</span>

  </div>

  <div class="step-box">

    <stepCom :statusConfig="props.statusConfig"></stepCom>

  </div>

  <div style="width: 100%; height: 290px">

    <tableCom :tableConfig="props.auditTableConfig">

      <!-- 这里就是最重要的部分 -->

      <template v-for="(slot, name) in $slots" :key="name" #[name]="{ row }">

        <slot :name="name" :row="row"></slot>

      </template>

    </tableCom>

  </div>

</div>

总结

需要加上一个 template 标签,然后循环所有的插槽,然后把插槽的 name,和 row 传递给子组件,子组件再把这个插槽原样传递给孙组件。

javascript 复制代码
<template v-for="(slot, name) in $slots" :key="name" #[name]="{ row }">

  <slot :name="name" :row="row"></slot>

</template>
相关推荐
英俊潇洒美少年5 分钟前
前端组件化开发最佳实践 + 高频面试题(Vue & React)
前端·vue.js·react.js
凌览7 分钟前
别再手搓 Skill 了,用这个工具 5 分钟搞定
前端·后端
zero159710 分钟前
TypeScript 快速实战系列:函数进阶|TypeScript 函数 + 异步:大模型 API 调用核心
前端·typescript·大模型编程语言
無名路人12 分钟前
用 codex AI 更新了下之前写的浏览器云书签标签页扩展
前端·openai·ai编程
月弦笙音17 分钟前
【pnpm 】pnpm 执行 xxx 的 底层原理
前端
玄空z26 分钟前
通俗理解 RAG 与微调:给大模型“翻书”还是“洗脑”
javascript
Devin_chen37 分钟前
单例模式渐进式学习指南
前端·javascript
苏西的网络日志1 小时前
基于 Element Plus 的企业级主题定制方案:SCSS 变量覆盖 + Vite 全局注入实战
前端
吴声子夜歌1 小时前
Vue3——计算属性和监听属性
前端·vue.js
苏西的网络日志1 小时前
小程序 web-view 内嵌 H5 的会话管理:Token 失效跳转登录的完整方案
前端