嘿!!
在开发中,我们会经常封装一个个可复用的组件,前面我们会通过props传递给组件一些数据,让组件来进行展示,但是为了让这个组件具备更强的通用性,我们不能将组件中的内容限制为固定的div、span等等这些元素;,比如某种情况下我们使用组件希望组件显示的是一个按钮,某种情况下我们使用组件希望显示的是一张图片,我们应该让使用者可以决定某一块区域到底存放什么内容。
你看,这几个导航栏组件有点相似,可以分为三个部分,左中右,其中中间内容不一样
定义插槽slot:
使用slot:
组件 里面有个插槽
<template>
<div>
<h2>MySlotCpn开始</h2>
<slot></slot>
<h2>MySlotCpn结尾</h2>
</div>
</template>
使用这个组件
<template>
<div>
<my-slot-cpn>
<!-- 1.普通的内容 -->
Hello World
<!-- 2.html元素 -->
<button>我是按钮</button>
<!-- 3.组件元素 -->
<my-button></my-button>
</my-slot-cpn>
</div>
</template>
当使用组件时,没插入内容,可以在插槽里自定义默认内容
<template>
<div>
<h2>MySlotCpn开始</h2>
<slot>默认内容</slot>
<h2>MySlotCpn结尾</h2>
</div>
</template>
<template>
<div>
<my-slot-cpn>
</my-slot-cpn>
</div>
</template>
v-slot
的参数的形式提供其名称<template>
<div>
<nav-bar>
<template v-slot:left>
<button>左边按钮</button>
</template>
<template v-slot:center>
<h2>中间标题</h2>
</template>
<template v-slot:right>
<i>右边i元素</i>
</template>
</nav-bar>
</div>
</template>
<template>
<div>
<slot name='default'></slot> //默认无名的是default
<slot name='right'></slot>
<slot name='left'></slot>
<slot name='center'></slot>
</div>
</template>
#
<template>
<div>
<nav-bar>
<template #left>
<button>左边按钮</button>
</template>
<template #center>
<h2>中间标题</h2>
</template>
<template #right>
<i>右边i元素</i>
</template>
</nav-bar>
</div>
</template>
动态具名插槽:
有时候我们希望插槽可以访问到子组件中的内容是非常重要的,当一个组件被用来
渲染一个数组元素
时,我们使用插槽,并且希望插槽中没有显示每项的内容
,这个Vue给我们提供了作用域插槽
App.vue代码
<template>
<div>
<show-names :names="names">
<template v-slot:default="slotProps">
<span>{{slotProps.item}}-{{slotProps.index}}</span>
</template>
</show-names>
</div>
</template>
<script>
import ShowNames from './ShowNames.vue';
export default {
components: {
ShowNames,
},
data() {
return {
names: ["why", "kobe", "james", "curry"]
}
}
}
</script>
ShowNames.vue
<template>
<div>
<template v-for="(item, index) in names" :key="item">
<!-- 插槽prop -->
<slot :item="item" :index="index"></slot>
</template>
</div>
</template>
<script>
export default {
props: {
names: {
type: Array,
default: () => []
}
}
}
</script>
如果我们的插槽是默认插槽default,那么在使用的时候 v-slot:default="slotProps"可以简写为v-slot=“slotProps”
<show-names :names="names">
<template v-slot="slotProps">
<span>{{slotProps.item}}-{{slotProps.index}}</span>
</template>
</show-names>