1、使用slot站位,不传内容,显示默认值
javascript
//父组件
import SlotChild from './projectConstruction-child/SlotChild.vue'
<div>
<SlotChild></SlotChild>
</div>
//子组件
<template>
<div>下面是插槽内容</div>
<div><slot>我是默认值</slot></div>
</template>
data:image/s3,"s3://crabby-images/331c5/331c552408c7e9a785618f3bf6fd398e94561e49" alt=""
2、使用slot站位,传内容,不显示默认值
javascript
//父组件
import SlotChild from './projectConstruction-child/SlotChild.vue'
<div>
<SlotChild>text</SlotChild>
</div>
//子组件
<template>
<div>下面是插槽内容</div>
<div><slot>我是默认值</slot></div>
</template>
data:image/s3,"s3://crabby-images/a1a7a/a1a7a2e8dc28ef4ae7bd7810ecc996b3fac0b919" alt=""
3、多个插槽时为了分清每一个插槽 所以需要 具名插槽 传值显示值,不传显示默认值
javascript
//父组件
<SlotChild>
<template #header>
<h3>text</h3>
</template>
<template>
<h3>foot</h3>
</template>
</SlotChild>
//子组件
<template>
<div>下面是插槽内容</div>
<div><slot name="header">我是默认值</slot></div>
<div><slot name="footer">我是默认值</slot></div>
</template>
data:image/s3,"s3://crabby-images/5daf3/5daf315b5dc61836b0be8642c1a762961fc553de" alt=""
4、作用域插槽
javascript
//父组件 #main="data" 接收slot传来的值
<SlotChild>
<template #header>
<h3>text</h3>
</template>
<template #main="data">
<h3>{{ data }}</h3>
</template>
<template>
<h3>foot</h3>
</template>
</SlotChild>
//子组件 传递数据slotArr
<template>
<div>下面是插槽内容</div>
<div><slot name="header">我是默认值</slot></div>
<div><slot name="main" :arr="slotArr"></slot></div>
<div><slot name="footer">我是默认值</slot></div>
</template>
<script setup lang="ts">
import { ref } from 'vue'
const slotArr = ref(['aaa', 'bbb', 'ccc', 'ddd'])
</script>
data:image/s3,"s3://crabby-images/8f239/8f2396888287ac8ce72830b272644e90dd8dad36" alt=""
5、遍历数据
javascript
//父组件
<SlotChild>
<template #header>
<h3>text</h3>
</template>
<template #main="data">
<ul>
<li v-for="e in data.arr" :key="e">{{ e }}</li>
</ul>
</template>
<template>
<h3>foot</h3>
</template>
</SlotChild>
//子组件
<template>
<div>下面是插槽内容</div>
<div><slot name="header">我是默认值</slot></div>
<div><slot name="main" :arr="slotArr"></slot></div>
<div><slot name="footer">我是默认值</slot></div>
</template>
<script setup lang="ts">
import { ref } from 'vue'
const slotArr = ref(['aaa', 'bbb', 'ccc', 'ddd'])
</script>
data:image/s3,"s3://crabby-images/ca07b/ca07b53e87a3c905add9b762ec94a1b0028da327" alt=""