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组件系统中一个非常强大的特性,它提供了一种灵活的方式来创建高度定制的组件,同时保持组件逻辑的封装和可重用性。

相关推荐
qq_316837755 小时前
uni.chooseMedia 读取base64 或 二进制
开发语言·前端·javascript
Zoey的笔记本5 小时前
2026告别僵化工作流:支持自定义字段的看板工具选型与部署指南
大数据·前端·数据库
小二·5 小时前
Python Web 开发进阶实战:混沌工程初探 —— 主动注入故障,构建高韧性系统
开发语言·前端·python
gis开发5 小时前
【无标题】
java·前端·javascript
小二·6 小时前
Python Web 开发进阶实战:低代码平台集成 —— 可视化表单构建器 + 工作流引擎实战
前端·python·低代码
慧一居士6 小时前
Vite 中配置环境变量方法及完整示例
前端·vue.js
梦因you而美6 小时前
XPath 元素定位全方位技术文档
javascript·xpath·xpath定位
天意pt6 小时前
Idempotency 幂等性 - 点赞和投票功能
前端·javascript·express
weixin_427771617 小时前
cursor 智能commit
前端
努力的小陈^O^7 小时前
问题:Spring循环依赖问题排查与解决
java·开发语言·前端