插槽
插槽
作用:让父组件可以向子组件指定位置插入html结构,也是一种组件间通信的方式,适用于 父组件 ===> 子组件 。
分类:默认插槽、具名插槽、作用域插槽
使用方式:
默认插槽:
1
2
3
4
5
6
7
8
9
10
11父组件中:
<Category>
<div>html结构1</div>
</Category>
子组件中:
<template>
<div>
<!-- 定义插槽 -->
<slot>插槽默认内容...</slot>
</div>
</template>具名插槽:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19父组件中:
<Category>
<!-- 这里 通过slot声明是哪个插槽 -->
<template slot="center">
<div>html结构1</div>
</template>
<template v-slot:footer>
<div>html结构2</div>
</template>
</Category>
子组件中:
<template>
<div>
<!-- 定义插槽 -->
<slot name="center">插槽默认内容...</slot>
<slot name="footer">插槽默认内容...</slot>
</div>
</template>作用域插槽:
理解:数据在组件的自身,但根据数据生成的结构需要组件的使用者来决定。简单来说可以定义为:让插槽中的内容能访问子组件中的数据。(games数据在Category组件中,但使用数据所遍历出来的结构由App组件决定)
具体编码:
这里需要注意一点版本的变化
v-slot 指令自 Vue 2.6.0 起被引入,提供更好的支持 slot 和 slot-scope attribute 的 API 替代方案。v-slot 完整的由来参见这份 RFC。在接下来所有的 2.x 版本中 slot 和 slot-scope attribute 仍会被支持,但已经被官方废弃且不会出现在 Vue 3 中。也就是说,在vue2版本中,我们仍可以使用slot跟slot-scope,但是在vue3中就只能使用v-slot了。
原来的带有slot的具名插槽
//B.vue
1 | |
写法变化,使用v-slot
1 | |
原来的作用域插槽
写法变化,使用v-slot
插槽
https://tian-1-2.github.io/typblog/2022/10/19/20221019-插槽/