插槽(Slots)(完整详细版)

一、匿名插槽

1.适用场景

子组件中只有一个位置允许父组件自定义内容

2.使用方法

第一步:在子组件中定义slot插槽

子组件 复制代码
<template>
  <div>
    <header>头部</header>
    <slot></slot>
    <footer>尾部</footer>
  </div>
</template>

第二步:在父组件中的子组件标签内直接填写需要插入的内容

父组件 复制代码
<template>
  <div>
    <TestComOne>
      <p>插入的新内容</p>
    </TestComOne>
  </div>
</template>

最终在子组件渲染出来的结果:

渲染 复制代码
<template>
  <div>
    <header>头部</header>
    <p>插入的新内容</p>
    <footer>尾部</footer>
  </div>
</template>

当父组件中没有提供插槽内容时,我们也可以给子组件的插槽中添加默认内容

添加默认内容 复制代码
<template>
  <div>
    <header>头部</header>
    <slot>默认内容</slot>
    <footer>尾部</footer>
  </div>
</template>

最终在子组件渲染出来的结果:

渲染 复制代码
<template>
  <div>
    <header>头部</header>
    默认内容
    <footer>尾部</footer>
  </div>
</template>

二、具名插槽

1.适用场景

子组件中有多个位置允许父组件自定义内容

2.使用方法

第一步:在子组件中定义多个slot插槽,并且为每个插槽添加一个特殊的attribute name

多个插槽 复制代码
<template>
  <div>
    <slot name="slotTop"></slot>
    <header>头部</header>
    <slot name="slotContent"></slot>
    <footer>尾部</footer>
    <slot name="slotBottom"></slot>
  </div>
</template>

第二步:在父组件中使用对应的插槽名

父组件中使用多个插槽 复制代码
<template>
  <div>
    <TestComOne>
      <template #slotTop>头部上面</template>
      <template #slotContent>中间</template>
      <template #slotBottom>尾部下面</template>
    </TestComOne>
  </div>
</template>

三、作用域插槽

1.为什么要使用作用域插槽

在某些场景下,我们想要插槽的内容使用到子组件域内的数据,这时候就需要用到插槽

2.使用方法

第一步:在子组件中,可以像组件传递props那样,向一个插槽slot传递attributes

子组件添加attributes 复制代码
<template>
  <div>
    <slot name="slotTop"></slot>
    <header>头部</header>
    <slot name="slotContent" height="180" :list="list"></slot>
    <footer>尾部</footer>
    <slot name="slotBottom"></slot>
  </div>
</template>

<script setup lang="ts">
import { ref } from "vue";
const list = ref({ name: "张三", old: 18 });
</script>

第二步:在父组件中使用解构赋值,拿到对应的值

父组件中使用 复制代码
<template>
  <div>
    <TestComOne>
      <template #slotContent="{ height, list }">
        <p>身高:{{ height }}</p>
        <p>姓名:{{ list.name }}</p>
        <p>年龄:{{ list.old }}</p>
      </template>
    </TestComOne>
  </div>
</template>

<script setup lang="ts">
import TestComOne from "./components/index.vue";
</script>
相关推荐
沙振宇2 分钟前
【Web】使用Vue3+PlayCanvas开发3D游戏(六)模拟自驾场景SR+3D可视化
前端·游戏·3d·vue3·playcanvas
吴所畏惧8 分钟前
前端打包cdn或者dll打包方式
前端
小鲤鱼ya11 分钟前
vue3 + ts + uni-app 移动端封装图片上传添加水印
前端·typescript·uni-app·vue3
霍理迪13 分钟前
Vue—条件渲染与循环渲染
前端·javascript·vue.js
xixixin_17 分钟前
【CSS】字体大小不一致?px与vw渲染差异的底层原理与解决方案
前端·css
小J听不清22 分钟前
CSS 内边距(padding)全解析:取值规则 + 表格实战
前端·javascript·css·html·css3
zhangjikuan8923 分钟前
在 ArkTS 中,Promise 的使用比 TypeScript 更严格(必须显式指定泛型类型)
前端·javascript·typescript
桐溪漂流23 分钟前
Uni-app H5 环境下 ResizeObserver 监听 mp-html 动态高度
前端·uni-app·html
Highcharts.js25 分钟前
React 如何实现大数据量图表(性能优化指南)
前端·javascript·react.js·信息可视化·集成·highcharts
奔跑的呱呱牛26 分钟前
如何设计一个可扩展的地图前端架构?从0到1的工程实践(OpenLayers)
前端·架构·openlayers