Vue 之组件插槽Slot用法(组件间通信一种方式)

1)插槽由来和分类

在某些场景中,我们可能想要在父组件为子组件传递一些模板片段,让子组件在它们的组件中渲染这些片段。

这就是插槽的作用。插槽分多种,默认插槽、具名插槽、条件插槽、动态插槽、作用域插槽。

2)插槽类型和举栗子

1.默认插槽

<slot></slot>

举栗子:

父组件:子组件的插槽写在哪里,父组件传递的内容就在哪里展示

<template>
  <div>我是父组件</div>
  <son>
    我是父组件给子组件的插槽
  </son>
</template>

<script setup>
import son from './son.vue'
</script>

子组件:

<template>
  <h3>我是子组件</h3>
  <br>
  <slot></slot>
</template>

2.具名插槽,一个子组件可以存在多个

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

父组件:父组件使用具名插槽有2种写法

<template>
  <div>我是父组件</div>
  <son>
    我是父组件给子组件的插槽
    <!-- 具名插槽写法1 -->
    <!-- <template v-slot:header>
      header插槽
    </template> -->
    <!-- 具名插槽写法2 -->
    <template #header>
      header插槽
    </template>
  </son>
</template>

子组件:

<template>
  <h3>我是子组件</h3>
  <br>
  <slot></slot>
  <br>
  <slot name="header"></slot>
</template>

3.条件插槽,主要是为了给插槽提供额外的样式

  <div v-if="slots.header" class="trans-header">
    <slot name="header"></slot>
  </div>
  <div v-if="slots.footer" class="trans-footer">
    <slot name="footer"></slot>
  </div>

举栗子:

父组件:

<template>
  <div>我是父组件</div>
  <son>
    <template #header>
      header插槽
    </template>
    <template #footer>
      footer插槽
    </template>
  </son>
</template>

<script setup>
import son from './son.vue'
</script>

子组件:

<template>
  <h3>我是子组件</h3>
  <br>
  <slot></slot>
  <br>
  <div v-if="slots.header" class="trans-header">
    <slot name="header"></slot>
  </div>
  <div v-if="slots.footer" class="trans-footer">
    <slot name="footer"></slot>
  </div>
</template>

<script setup>
import { onMounted, useSlots } from "vue";
const slots = useSlots()
onMounted(() => {
  // 可以通过slots判断传递了哪些插槽
  console.log(slots);
})

</script>

4.动态插槽,动态传入插槽名

<son>
  <!-- 该属性dynamicSlotName为动态数据,在js定义并传递 -->
  <template v-slot:[dynamicSlotName]>
    ...
  </template>

  <!-- 缩写为 -->
  <template #[dynamicSlotName]>
    ...
  </template>
</son>

5.作用域插槽

父组件:父组件传递给子组件的数据,可以通过插槽再次传递给父组件使用,封装组件时非常常用

<template>
  <div>我是父组件</div>
  <son :obj1="obj1" :obj2="obj2">
    我是父组件给子组件的插槽
    <template #header="slot">
      header插槽{{ slot.obj1 }}
    </template>
    <template #footer="slot">
      footer插槽{{ slot.obj2 }}
    </template>
  </son>
</template>

<script setup>
import { reactive } from 'vue';
import son from './son.vue'
const obj1 = reactive({ name: '羊羊', age: 12 });
const obj2 = reactive({ name: '猫猫', age: 2 });
</script>

子组件:

<template>
  <h3>我是子组件</h3>
  <br>
  <slot></slot>
  <br>
  <slot name="header" :obj1="obj1"></slot>
  <slot name="footer" :obj2="obj2"></slot>
</template>

<script setup>
const props = defineProps({
  obj1: {
    type: Object, default: () => { }
  },
  obj2: {
    type: Object, default: () => { }
  },
})
</script>

如有不足,欢迎指正。

不要忽视你达成的每个小练习,它是你前进路上的垫脚石。冲!

相关推荐
长风清留扬20 分钟前
小程序毕业设计-音乐播放器+源码(可播放)下载即用
javascript·小程序·毕业设计·课程设计·毕设·音乐播放器
web1478621072333 分钟前
C# .Net Web 路由相关配置
前端·c#·.net
m0_7482478034 分钟前
Flutter Intl包使用指南:实现国际化和本地化
前端·javascript·flutter
飞的肖37 分钟前
前端使用 Element Plus架构vue3.0实现图片拖拉拽,后等比压缩,上传到Spring Boot后端
前端·spring boot·架构
青灯文案11 小时前
前端 HTTP 请求由 Nginx 反向代理和 API 网关到后端服务的流程
前端·nginx·http
m0_748254881 小时前
DataX3.0+DataX-Web部署分布式可视化ETL系统
前端·分布式·etl
ZJ_.1 小时前
WPSJS:让 WPS 办公与 JavaScript 完美联动
开发语言·前端·javascript·vscode·ecmascript·wps
GIS开发特训营1 小时前
Vue零基础教程|从前端框架到GIS开发系列课程(七)响应式系统介绍
前端·vue.js·前端框架·gis开发·webgis·三维gis
Cachel wood2 小时前
python round四舍五入和decimal库精确四舍五入
java·linux·前端·数据库·vue.js·python·前端框架
学代码的小前端2 小时前
0基础学前端-----CSS DAY9
前端·css