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>

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

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

目录
相关文章
|
1天前
|
JavaScript 定位技术
BIGEMAP地图VUE中引入
BIGEMAP地图VUE中引入
3 0
BIGEMAP地图VUE中引入
|
1天前
|
JavaScript
vue点击按钮复制文字到粘贴板
vue点击按钮复制文字到粘贴板
6 0
|
1天前
|
JavaScript 定位技术 开发者
vue项目使用腾讯地图获取定位
vue项目使用腾讯地图获取定位
4 0
|
1天前
|
JavaScript 开发者
如何新建一个vue+vant移动端项目
如何新建一个vue+vant移动端项目
6 0
|
JavaScript
初识 Vue(19)---(Vue 中使用插槽(slot))
Vue 中使用插槽(slot) 案例:子组件中的一部分内容是根据父组件传递来的 DOM 来进行显示 Vue 中使用插槽(slot) Vue.
1235 0
|
5天前
|
前端开发 JavaScript
Vue底层实现原理总结
Vue底层实现原理总结
|
10天前
|
JavaScript 前端开发 测试技术
使用 Vue CLI 脚手架生成 Vue 项目
通过 Vue CLI 创建 Vue 项目可以极大地提高开发效率。它不仅提供了一整套标准化的项目结构,还集成了常用的开发工具和配置,使得开发者可以专注于业务逻辑的实现,而不需要花费大量时间在项目配置上。
71 7
使用 Vue CLI 脚手架生成 Vue 项目
|
1天前
|
JavaScript
Vue全局注册与局部注册异同点
Vue全局注册与局部注册异同点
12 6
|
1天前
|
JavaScript
Vue的小知识点
Vue的小知识点
7 2