当前位置:首页 > VUE

vue slot实现

2026-01-12 17:59:29VUE

Vue Slot 实现方法

Vue 的 slot(插槽)是一种内容分发机制,允许父组件向子组件传递模板片段,实现灵活的组件复用。以下是 slot 的核心用法和实现方式:

默认插槽

子组件通过 <slot> 标签定义插槽位置,父组件传递的内容会替换该标签:

vue slot实现

<!-- 子组件 Child.vue -->
<template>
  <div>
    <slot>默认内容(当父组件未传递内容时显示)</slot>
  </div>
</template>

<!-- 父组件 -->
<Child>
  <p>父组件插入的内容</p>
</Child>

具名插槽

通过 name 属性定义多个插槽,父组件用 v-slot 指令指定目标插槽:

vue slot实现

<!-- 子组件 Layout.vue -->
<template>
  <div>
    <header>
      <slot name="header"></slot>
    </header>
    <main>
      <slot></slot>  <!-- 默认插槽 -->
    </main>
  </div>
</template>

<!-- 父组件 -->
<Layout>
  <template v-slot:header>
    <h1>标题内容</h1>
  </template>
  <p>主内容(自动插入默认插槽)</p>
</Layout>

作用域插槽

子组件通过插槽向父组件传递数据,父组件可基于数据自定义渲染逻辑:

<!-- 子组件 List.vue -->
<template>
  <ul>
    <li v-for="item in items" :key="item.id">
      <slot :item="item"></slot>
    </li>
  </ul>
</template>

<!-- 父组件 -->
<List :items="listData">
  <template v-slot:default="slotProps">
    <span>{{ slotProps.item.name }}</span>
  </template>
</List>

动态插槽名

通过动态指令参数绑定插槽名:

<template v-slot:[dynamicSlotName]>
  <!-- 内容 -->
</template>

缩写语法

  • v-slot:header 可缩写为 #header
  • 默认插槽可缩写为 v-slot="slotProps"#default="slotProps"

注意事项

  • 默认插槽和具名插槽不能混合使用(Vue 2 中会警告,Vue 3 中会报错)。
  • 作用域插槽的数据传递遵循单向数据流原则。
  • Vue 3 中废弃了 slotslot-scope 属性,统一使用 v-slot 指令。

标签: vueslot
分享给朋友:

相关文章

vue 表格实现

vue 表格实现

Vue 表格实现方法 在 Vue 中实现表格功能可以通过多种方式完成,以下介绍几种常见的方法: 使用原生 HTML 表格 最简单的表格可以通过 Vue 模板中的原生 HTML 表格元素实现: &l…

vue实现查询替换

vue实现查询替换

Vue 实现查询替换功能 在 Vue 中实现查询替换功能,可以通过数据绑定和字符串操作方法结合实现。以下是具体实现方式: 基础实现 <template> <div>…

用vue实现滑动输入条

用vue实现滑动输入条

使用 Vue 实现滑动输入条 使用原生 HTML5 input range 实现 在 Vue 模板中直接使用 <input type="range">,通过 v-model 绑定数据:…

vue实现生成二维码

vue实现生成二维码

使用qrcode.vue库生成二维码 安装qrcode.vue库: npm install qrcode.vue --save 在Vue组件中使用: <template> <…

vue实现发表

vue实现发表

Vue 实现发表功能 在 Vue 中实现发表功能通常涉及表单处理、数据绑定和网络请求。以下是实现步骤和代码示例: 表单设计与数据绑定 创建一个表单用于输入发表内容,使用 v-model 进行数据双向…

vue 实现复选

vue 实现复选

Vue 实现复选功能 在 Vue 中实现复选功能可以通过多种方式完成,以下是常见的几种方法: 使用 v-model 绑定数组 通过 v-model 绑定一个数组,可以自动收集用户选择的复选框值。…