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>

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

本文为作者原创,手码不易,允许转载,转载后请以链接形式说明文章出处。

目录
相关文章
|
12天前
|
JavaScript 关系型数据库 MySQL
基于VUE的校园二手交易平台系统设计与实现毕业设计论文模板
基于Vue的校园二手交易平台是一款专为校园用户设计的在线交易系统,提供简洁高效、安全可靠的二手商品买卖环境。平台利用Vue框架的响应式数据绑定和组件化特性,实现用户友好的界面,方便商品浏览、发布与管理。该系统采用Node.js、MySQL及B/S架构,确保稳定性和多功能模块设计,涵盖管理员和用户功能模块,促进物品循环使用,降低开销,提升环保意识,助力绿色校园文化建设。
|
1天前
|
JavaScript
vue使用iconfont图标
vue使用iconfont图标
25 1
|
2月前
|
JavaScript API 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
2月前
|
JavaScript 前端开发 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
2月前
|
存储 JavaScript 前端开发
介绍一下Vue的核心功能
介绍一下Vue的核心功能
|
JavaScript API
Vue | Vuejs 组件化 - 插槽Slot/非父子通信
Vue | Vuejs 组件化 - 插槽Slot/非父子通信
|
JavaScript
Vue插槽 slot 标签
Vue插槽 slot 标签
135 0
|
8月前
|
JavaScript
VUE组件: 请解释Vue的插槽(slot)是什么?
VUE组件: 请解释Vue的插槽(slot)是什么?
61 1
|
JavaScript 前端开发
Vue系列教程(14)- 插槽(slot)
Vue系列教程(14)- 插槽(slot)
73 0
|
JavaScript 前端开发
Vue之插槽Slot理解
Vue之插槽Slot理解
103 0

热门文章

最新文章