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>
相关推荐
Codebee4 分钟前
OneCode3.0-RAD 可视化设计器 配置手册
前端·低代码
深兰科技6 分钟前
深兰科技:搬迁公告,我们搬家了
javascript·人工智能·python·科技·typescript·laravel·深兰科技
chxii18 分钟前
6.4 Element UI 中的 <el-table> 表格组件
vue.js·ui·elementui
葡萄城技术团队20 分钟前
【SpreadJS V18.2 新版本】设计器新特性:四大主题方案,助力 UI 个性化与品牌适配
前端
lumi.29 分钟前
Swiper属性全解析:快速掌握滑块视图核心配置!(2.3补充细节,详细文档在uniapp官网)
前端·javascript·css·小程序·uni-app
调皮LE31 分钟前
可放大缩小弹窗组件,基于element-ui的vue2版本
前端
陈随易34 分钟前
10年老前端,分享20+严选技术栈
前端·后端·程序员
我的小月月40 分钟前
基于Canvas实现的网页取色器功能解析
前端
芝士加1 小时前
还在用html2canvas?介绍一个比它快100倍的截图神器!
前端·javascript·开源
阿虎儿1 小时前
React 引用(Ref)完全指南
前端·javascript·react.js