Vue 3插槽

  • Vue 3中的插槽(Slots)是一种强大的模式,用于创建可复用的组件,它允许你将模板插入到组件内部,同时保持组件的封装性和可重用性。在Vue 3中,插槽的使用变得更加灵活和强大。

基本插槽

  1. 默认插槽 :
    在子组件中,使用<slot>标签定义一个插槽。父组件中的任何内容都将替换这个<slot>标签。
vue 复制代码
<!-- 子组件 -->
<template>
  <div>
    <slot></slot> <!-- 默认插槽 -->
  </div>
</template>
vue 复制代码
<!-- 父组件 -->
<template>
  <ChildComponent>
    这里的内容会显示在子组件的插槽中。
  </ChildComponent>
</template>

具名插槽

  1. 定义具名插槽 :
    使用name属性在子组件中定义多个插槽。
vue 复制代码
<!-- 子组件 -->
<template>
  <div>
    <slot name="header"></slot> <!-- 具名插槽 -->
    <slot></slot> <!-- 默认插槽 -->
    <slot name="footer"></slot> <!-- 另一个具名插槽 -->
  </div>
</template>
  1. 使用具名插槽 :
    父组件使用v-slot指令指定要填充的插槽。
vue 复制代码
<!-- 父组件 -->
<template>
  <ChildComponent>
    <template v-slot:header>
      这里是头部内容。
    </template>

    这里是默认插槽的内容。

    <template v-slot:footer>
      这里是底部内容。
    </template>
  </ChildComponent>
</template>

作用域插槽

  1. 定义作用域插槽 :
    子组件可以通过作用域插槽向父组件传递数据。
vue 复制代码
<!-- 子组件 -->
<template>
  <div>
    <slot name="item" v-for="item in items" :item="item"></slot>
  </div>
</template>
  1. 使用作用域插槽 :
    父组件可以使用这些数据来定制插槽的内容。
vue 复制代码
<!-- 父组件 -->
<template>
  <ChildComponent>
    <template v-slot:item="slotProps">
      <div>{{ slotProps.item.name }}</div>
    </template>
  </ChildComponent>
</template>

插槽的默认内容

  1. 提供默认内容 :
    在子组件的插槽中可以定义默认内容。如果父组件没有提供内容,将显示默认内容。
vue 复制代码
<!-- 子组件 -->
<template>
  <div>
    <slot>默认内容</slot>
  </div>
</template>

注意事项

  • 插槽内容是在父组件中编译的,而不是在子组件中。
  • 作用域插槽可以让父组件访问子组件中的数据。
  • 使用插槽时,遵循单向数据流的原则,避免直接修改子组件传递给父组件的数据。

插槽是Vue组件系统中一个非常强大的特性,它提供了一种灵活的方式来创建高度定制的组件,同时保持组件逻辑的封装和可重用性。

相关推荐
抱琴_7 分钟前
【Vue3】大屏性能优化黑科技:Vue 3 中实现请求合并,让你的大屏飞起来!
前端·vue.js
不会玩电脑的Xin.9 分钟前
HTML + CSS
前端·css·html
hadage23329 分钟前
--- JavaScript 的一些常用语法总结 ---
java·前端·javascript
彭于晏爱编程30 分钟前
🍭🍭🍭升级 AntD 6:做第一个吃螃蟹的人
前端
掘金一周41 分钟前
大部分人都错了!这才是chrome插件多脚本通信的正确姿势 | 掘金一周 11.27
前端·人工智能·后端
saberxyL1 小时前
通过<RouterView/>来切换页面组件时,transition如何生效?
vue.js
jason_yang1 小时前
vue3中createApp多个实例共享状态
javascript·vue.js
_瑶瑶_1 小时前
浅记一下ElementPlus中的虚拟化表格(el-table-v2)的简单使用
前端·javascript
Drift_Dream1 小时前
ResizeObserver:轻松监听元素尺寸变化
前端