Vue 插槽 slot 学习

<template>
    <div class="father">
        <h3>这里是父组件</h3>
        <child>
            <div class="tmpl">
              <span>菜单1</span>
              <span>菜单2</span>
            </div>
        </child>
    </div>
</template>

<template>
    <div class="child">
        <h3>这里是子组件</h3>
    </div>
</template>

看上面的代码,父模板里面显示子模板 ,显示结果是不会显示菜单1 菜单2 的. 那如果想在子模板里面显示菜单1 菜单2 该怎么办了呢?

<template>
    <div class="child">
        <h3>这里是子组件</h3>
        <slot></slot>
    </div>
</template>

添加slot 插槽,这就是slot 存在的意义.

插槽分为 匿名插槽,具名插槽,作用域插槽.

匿名插槽
<slot></slot>
具名插槽
<slot name="up"></slot>

作用域插槽
<slot name="up" :data="data"></slot>
 export default {
    data: function(){
      return {
        data: ['zhangsan','lisi','wanwu','zhaoliu','tianqi','xiaoba']
      }
    },
}

什么时候该用哪个插槽? 这个主要看父模板里面想怎么用了.

这是具名插槽的用法,通过名字可以指定想插入哪个位置

<template>
  <div class="father">
    <h3>这里是父组件</h3>
    <child>
      <div class="tmpl" slot="up">
        <span>菜单1</span>
      </div>
    </child>
  </div>
</template>

<template>
  <div class="child">
    // 具名插槽
    <slot name="up"></slot>
    <h3>这里是子组件</h3>
    <slot></slot>
  </div>
</template>

这是作用域插槽,父模板可以获取子模板里面的数据.

<template>
  <div class="father">
    <h3>这里是父组件</h3>
    <!--第一次使用:用flex展示数据-->
    <child>
      <template slot-scope="user">
        <div class="tmpl">
          <span v-for="item in user.data">{{item}}</span>
        </div>
      </template>
    </child>
 </div>
<template>

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 此文基于官方文档,里面部分例子有改动,加上了一些自己的理解 什么是组件? 组件(Component)是 Vue.j...
    陆志均阅读 3,868评论 5 14
  • 构造器 每一个Vue.js的应用都是通过够构造函数Vue创建的一个Vue的根实例。例如: 上述代码中在实例化vue...
    61ae56c48fc6阅读 5,453评论 2 4
  • 释义 slot, 解释为插槽,它是组件的一块 HTML模板,而这块模板 显示与否 以及 如何显示,取决于父组件。 ...
    心斐阅读 640评论 2 2
  • 本文为转载,原文:Vue学习笔记入门篇——组件的内容分发(slot) 介绍 为了让组件可以组合,我们需要一种方式来...
    ChainZhang阅读 3,225评论 2 11
  • 把思绪放到山海间 这样我可以 浪荡的跋山涉水 理由是寻找我自己 卑鄙的谎言蒙蔽不了任何人的双眼 掩耳盗铃这等事还在...
    MOON七阅读 283评论 0 0