vue3 插槽简洁清晰的教程
作者:拾荒旧痕 来源:blog.csdn.net 更新时间:2023-07-10 22:32
1. 1 具名插槽
案例1:有时我们需要多个插槽。例如对于一个带有如下模板的 <base-layout> 组件 (vue官网案例)
<div class="container">
<header>
<!-- 我们希望把页头放这里 -->
</header>
<main>
<!-- 我们希望把主要内容放这里 -->
</main>
<footer>
<!-- 我们希望把页脚放这里 -->
</footer>
</div>
child子组件中的使用:slot 元素有一个特殊的 attribute:name。这个 attribute 可以用来定义额外的插槽
<!-- 子组件 -->
<div class="container">
<header>
<slot name="header"></slot>
</header>
<main>
<slot></slot>
</main>
<footer>
<slot name="footer"></slot>
</footer>
</div>
father父组件中的使用:在向具名插槽提供内容的时候,我们可以在一个 元素上使用 v-slot 指令,并以 v-slot 的参数的形式提供其名称
<!-- 父组件 -->
<base-layout>
<template v-slot:header>
<h1>Here might be a page title</h1>
</template>
<template v-slot:default>
<p>A paragraph for the main content.</p>
<p>And another one.</p>
</template>
<template v-slot:footer>
<p>Here's some contact info</p>
</template>
</base-layout>
渲染结果:
<div class="container">
<header>
<h1>Here might be a page title</h1>
</header>
<main>
<p>A paragraph for the main content.</p>
<p>And another one.</p>
</main>
<footer>
<p>Here's some contact info</p>
</footer>
</div>
1.2 具名插槽(缩写)
跟 v-on 和 v-bind 一样,v-slot 也有缩写,即把参数之前的所有内容 (v-slot:) 替换为字符 #。例如 v-slot:header 可以被重写为 #header:
<base-layout>
<template #header>
<h1>Here might be a page title</h1>
</template>
<p>A paragraph for the main content.</p>
<p>And another one.</p>
<template #footer>
<p>Here's some contact info</p>
</template>
</base-layout>
2. 作用域插槽
- 作用域解析: 对于children子组件的作用域就是其父组件下的作用域(作用域的划分:看最外层的模板的作用域),对于如下代码里面的 arr 变量就是访问到父组件data里面的数据;如果我们要在father父组件里面访问到children子组件里面的数据要如何实现呢?
<!-- 父组件 -->
<template>
<div>
<children>
<span v-for="(itme,index) in arr" :key={index}>{{item}}<span>
</children>
</div>
</template>
<script>
export default {
data(){
return {
arr: ['php','java','python','javascript']
}
}
</script>
- 作用域插槽的目的 让父组件能够访问子组件中才有的数据!!!(借助插槽实现)
children子组件代码
<template>
<div>
<span>
<slot v-bind:user="user"></slot>
</span>
</div>
</template>
<script>
export default {
data(){
return {
user:{
name:'李明'
}
}
}
}
子组件: 将 user 作为 < slot >元素的一个 attribute 绑定上去
father父组件代码
<template>
<div>
<children>
<template v-slot:default="slotProps">
{{ slotProps.user.name}}
</template>
</children>
</div>
</template>
<script>
export default {
data(){
return {
}
}
}
父组件:绑定在 < slot > 元素上的 attribute 被称为插槽 prop。现在在父级作用域中,我们可以使用带值的 v-slot 来定义我们提供的插槽 prop 的名字 ,slotProps包含了所有的插槽prop
上一篇:css !important的问题 下一篇:ts 类型缩小的方式有哪些