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 语法糖。
  • 动态插槽可以通过计算属性或其他动态属性值来决定使用哪个插槽,但通常情况下直接使用上述方式已足够满足需求。

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

相关推荐
奕辰杰14 分钟前
关于npm前端项目编译时栈溢出 Maximum call stack size exceeded的处理方案
前端·npm·node.js
JiaLin_Denny2 小时前
如何在NPM上发布自己的React组件(包)
前端·react.js·npm·npm包·npm发布组件·npm发布包
_Kayo_2 小时前
VUE2 学习笔记14 nextTick、过渡与动画
javascript·笔记·学习
路光.3 小时前
触发事件,按钮loading状态,封装hooks
前端·typescript·vue3hooks
我爱996!3 小时前
SpringMVC——响应
java·服务器·前端
咔咔一顿操作4 小时前
Vue 3 入门教程7 - 状态管理工具 Pinia
前端·javascript·vue.js·vue3
kk爱闹4 小时前
用el-table实现的可编辑的动态表格组件
前端·vue.js
漂流瓶jz5 小时前
JavaScript语法树简介:AST/CST/词法/语法分析/ESTree/生成工具
前端·javascript·编译原理
换日线°5 小时前
css 不错的按钮动画
前端·css·微信小程序