当前位置:首页 > VUE

vue实现slot

2026-01-07 22:05:34VUE

Vue 中的 Slot 实现方法

Vue 的 slot 是一种内容分发机制,允许父组件向子组件插入内容。以下是几种常见的 Slot 实现方式:

默认 Slot

子组件通过 <slot> 标签定义插槽位置,父组件可以在子组件标签内插入内容。

子组件 (ChildComponent.vue):

<template>
  <div>
    <h2>子组件标题</h2>
    <slot></slot>
  </div>
</template>

父组件:

<template>
  <ChildComponent>
    <p>这是插入到子组件的内容</p>
  </ChildComponent>
</template>

具名 Slot

当需要多个插槽时,可以使用具名 Slot 进行区分。

子组件 (ChildComponent.vue):

<template>
  <div>
    <slot name="header"></slot>
    <slot></slot>
    <slot name="footer"></slot>
  </div>
</template>

父组件:

<template>
  <ChildComponent>
    <template v-slot:header>
      <h3>头部内容</h3>
    </template>

    <p>默认插槽内容</p>

    <template v-slot:footer>
      <p>底部内容</p>
    </template>
  </ChildComponent>
</template>

作用域 Slot

当子组件需要向插槽传递数据时,可以使用作用域 Slot。

子组件 (ChildComponent.vue):

<template>
  <div>
    <slot :user="user"></slot>
  </div>
</template>

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

父组件:

<template>
  <ChildComponent>
    <template v-slot:default="slotProps">
      <p>用户名: {{ slotProps.user.name }}</p>
      <p>年龄: {{ slotProps.user.age }}</p>
    </template>
  </ChildComponent>
</template>

动态 Slot 名

可以使用动态指令参数来定义动态 Slot 名称。

父组件:

<template>
  <ChildComponent>
    <template v-slot:[dynamicSlotName]>
      <p>动态插槽内容</p>
    </template>
  </ChildComponent>
</template>

<script>
export default {
  data() {
    return {
      dynamicSlotName: 'header'
    }
  }
}
</script>

缩写语法

Vue 提供了 Slot 的缩写语法,v-slot: 可以简写为 #

父组件:

vue实现slot

<template>
  <ChildComponent>
    <template #header>
      <h3>头部内容</h3>
    </template>
  </ChildComponent>
</template>

这些方法涵盖了 Vue 中 Slot 的主要使用场景,可以根据实际需求选择合适的方式实现组件间的灵活内容分发。

标签: vueslot
分享给朋友:

相关文章

vue 实现列表

vue 实现列表

Vue 实现列表的方法 在 Vue 中实现列表通常使用 v-for 指令,结合数组或对象数据渲染动态列表。以下是几种常见的实现方式: 基础列表渲染 使用 v-for 指令遍历数组,渲染列表项。ite…

vue实现编辑

vue实现编辑

Vue 实现编辑功能 在 Vue 中实现编辑功能通常涉及表单绑定、状态管理和事件处理。以下是一个常见的实现方法: 双向数据绑定 使用 v-model 指令实现表单元素与数据的双向绑定: <i…

vue实现 单选

vue实现 单选

实现 Vue 单选功能 在 Vue 中实现单选功能可以通过多种方式完成,以下是几种常见的方法: 使用 v-model 绑定单选按钮 通过 v-model 可以轻松实现单选功能,将单选按钮的值绑定到同…

vue实现循环

vue实现循环

Vue 实现循环的方法 在 Vue 中,可以通过 v-for 指令实现循环渲染列表或对象。以下是几种常见的用法: 遍历数组 使用 v-for 遍历数组时,可以同时获取当前项和索引: <ul&…

vue源码实现

vue源码实现

Vue 源码实现解析 Vue.js 的核心实现可以分为响应式系统、虚拟 DOM、模板编译、组件化等几个关键部分。以下是对这些核心机制的详细解析。 响应式系统 Vue 的响应式系统基于 Object.…

vue实现投票

vue实现投票

Vue实现投票功能 数据准备 在Vue组件的data中定义投票相关数据,包括选项列表和当前选中状态: data() { return { options: [ { id: 1…