Vue之插槽Slot理解

简介: Vue之插槽Slot理解

刚开始看的时候,以为Vue的插槽和React一样,我定睛一看,md原来不对,怎么越看越像Reactprops.children属性,但是比React这个属性要🐂一点。

插槽内容 (和children就一样了)

给大家搞个🌰

<my-component>这里的内容如果需要保留,就需要在my-component中使用 slot,如果不使用将丢弃这段内容</my-component>
<slot>如果组件被使用 中间并没有传递任何内容的话 这个作为后备内容,也就是默认内容, 如果传递了则覆盖</slot>

多个插槽

多个插槽使用 v-slot 这个指令只能放在 template 上,在使用slot的时候指定name属性,例如

  • my-component.vue
<div>
   <slot name="header"></slot>
</div>
  • main.vue
<div>
        <my-component>
            <template v-slot:header>    // 可以使用简写 #header
                这是头部插槽内容
            </template>
        </my-component>
    </div>

插槽作用域

主要解决一个常见问题:父组件如何获取子组件的数据 并渲染

  • my-component.vue
<template>
    <div>
         // 将headerData 通过v-bind暴露给父组件
        <slot name="header" v-bind:data="headerData"></slot>
    </div>
</template>
<script>
    export default {
        props: {
        },
        data() {
            return {
                headerData: {name: 'headerData'}
            };
        },
    };
</script>
  • main.vue
<div>
        <my-component>
            <template v-slot:header="slotProps">    // 获取到子组件的数据                
                {{slotProps.data.name}}             // 这就是数据
            </template>
        </my-component>
    </div>

注意:父组件在使用子组件的时候 插槽和具名插槽不能嵌套,这样会导致作用域不明确

插槽数据工作原理

实际上就是利用回调函数的机制

function (slotProps) {
  // 插槽内容. 数据就是传递的参数罢了 普通函数 利用回调函数的机制 这样的话还可以对 slotProps进行解构 (有点东西啊,卧槽)
}
// 看看人家的写法。有点想放弃react的冲动
<current-user v-slot="{ user = { firstName: 'Guest' } }">
  {{ user.firstName }}
</current-user>

插槽搞完了,快去看我别的文章吧!

目录
相关文章
|
4天前
|
JavaScript
Vue基础知识总结 4:vue组件化开发
Vue基础知识总结 4:vue组件化开发
|
4天前
|
存储 JavaScript
Vue 状态管理工具vuex
Vue 状态管理工具vuex
|
10天前
|
JavaScript
如何在 Vue 中使用具名插槽
【10月更文挑战第25天】通过使用具名插槽,你可以更好地组织和定制组件的模板结构,使组件更具灵活性和可复用性。同时,具名插槽也有助于提高代码的可读性和可维护性。
14 2
|
10天前
|
JavaScript
Vue 中的插槽
【10月更文挑战第25天】插槽的使用可以大大提高组件的复用性和灵活性,使你能够根据具体需求在组件中插入不同的内容,同时保持组件的结构和样式的一致性。
12 2
|
JavaScript API
Vue | Vuejs 组件化 - 插槽Slot/非父子通信
Vue | Vuejs 组件化 - 插槽Slot/非父子通信
|
JavaScript
Vue插槽 slot 标签
Vue插槽 slot 标签
126 0
|
6月前
|
JavaScript
VUE组件: 请解释Vue的插槽(slot)是什么?
VUE组件: 请解释Vue的插槽(slot)是什么?
49 1
|
12月前
|
JavaScript 前端开发
Vue系列教程(14)- 插槽(slot)
Vue系列教程(14)- 插槽(slot)
67 0
|
JavaScript
Vue(Vue2+Vue3)——54.插槽(slot)
Vue(Vue2+Vue3)——54.插槽(slot)
|
JavaScript