vue3插槽的使用

1. 默认插槽

默认插槽是最基本的形式,用于插入任何未明确命名的内容。

子组件 (Child.vue) 示例:

复制代码
<template>
  <div class="wrapper">
    <header>这是头部</header>
    <slot></slot> <!-- 默认插槽位置 -->
    <footer>这是尾部</footer>
  </div>
</template>

父组件使用示例:

复制代码
<child>
  <p>这里是父组件插入的默认内容</p>
</child>

2. 具名插槽

具名插槽允许你有选择性地插入内容到组件的特定位置。

子组件 (Child.vue) 示例:

复制代码
<template>
  <div class="container">
    <slot name="header"></slot>
    <slot name="main"></slot>
    <slot name="footer"></slot>
  </div>
</template>

父组件使用示例

复制代码
<child>
  <template v-slot:header>
    <h2>自定义头部</h2>
  </template>
  <template v-slot:main>
    <p>主要内容区域</p>
  </template>
  <template v-slot:footer>
    <p>版权信息</p>
  </template>
</child>

3. 作用域插槽

作用域插槽可以接收来自子组件的数据,使插槽内容能基于这些数据动态变化。

子组件 (Child.vue) 示例:

复制代码
<template>
  <div>
    <slot v-bind:user="userData"></slot>
  </div>
</template>

<script>
export default {
  data() {
    return {
      userData: { name: '张三', age: 25 }
    };
  }
};
</script>

父组件使用示例:

复制代码
<child>
  <template v-slot="{ user }">
    <p>姓名:{{ user.name }}</p>
    <p>年龄:{{ user.age }}</p>
  </template>
</child>

注意事项

  • Vue 2.x 使用 slotslot-scope,而Vue 3.x 及更高版本推荐使用 v-slot 语法糖。
  • 动态插槽可以通过计算属性或其他动态属性值来决定使用哪个插槽,但通常情况下直接使用上述方式已足够满足需求。

通过合理使用插槽,你可以设计出高度可复用和灵活的组件。

相关推荐
东东2332 分钟前
GeoJSON 介绍:Web 地图数据的通用语言
前端·javascript·json
之恒君3 分钟前
Promise.resolve(x) 等同 new Promise(resolve => resolve(x))?
前端·promise
Tzarevich3 分钟前
JavaScript 原型链:理解对象继承的核心机制
javascript·promise
亮子AI4 分钟前
【Javascript】jsondiffpatch检测到子节点改变了,父节点会标记为改变吗?
开发语言·前端·javascript
T___T22 分钟前
写着写着,就踩进了 JavaScript 的小坑
前端·javascript·面试
ERP老兵-冷溪虎山22 分钟前
Python/JS/Go/Java同步学习(第五十篇半)四语言“path路径详解“对照表: 看完这篇定位文件就通透了(附源码/截图/参数表/避坑指南)
java·javascript·python·golang·中医编程·编程四语言同步学·path路径详解
月亮慢慢圆26 分钟前
首字母模糊匹配
前端
一个有理想的摸鱼选手27 分钟前
CesiumLite-在三维地图中绘制3D图形变得游刃有余
前端·gis·cesium
一千柯橘27 分钟前
Three.js 坐标系完全入门:从“你在哪”到“你爸在哪”都讲清楚了
前端
独角仙梦境28 分钟前
同事:架构太复杂了,源码文件找半天。 我:源码溯源了解一下?
前端·vue.js