Vue

Vue slot用法

Posted by Jeremy on October 17, 2018

关于Vue slot的理解

slot是什么

slot,也就是插槽,是组件的一块HTML模板,这块模板显示不显示、以及怎样显示由父组件来决定。 实际上,一个slot最核心的两个问题在这里就点出来了,是显示不显示和怎样显示。

单个插槽 | 默认插槽 | 匿名插槽

首先是单个插槽,单个插槽是vue的官方叫法,但是其实也可以叫它默认插槽,或者与具名插槽相对,我们可以叫它匿名插槽。因为它不用设置name属性。

单个插槽可以放置在组件的任意位置,但是就像它的名字一样,一个组件中只能有一个该类插槽。相对应的,具名插槽就可以有很多个,只要名字(name属性)不同就可以了。
下面通过一个例子来展示。


父组件:
<template>
    <div class="fourth-container">
        <h3>我是父组件</h3>
        <child>
            <span>我是文字</span>
        </child>
    </div>
</template>


子组件:
<template>
    <div class="lockInfo">
        <h3>我是是子组件</h3>
        <slot></slot>
    </div>
</template>   

页面显示

页面渲染

如果没有slot站位父组件嵌套在子组件中的内容不会显示出来

具名插槽

匿名插槽没有name属性,所以是匿名插槽,那么,插槽加了name属性,就变成了具名插槽。具名插槽可以在一个组件中出现N次,出现在不同的位置。下面的例子,就是一个有两个具名插槽和单个插槽的组件,这三个插槽被父组件用同一套css样式显示了出来,不同的是内容上略有区别。

父组件:
    <template>
        <div class="fourth-container">
            <h3>我是父组件</h3>
            <child>
                <span slot='header'>具名插槽header</span>
                <span>匿名插槽</span>
                <span slot='footer'>具名插槽footer</span>        
            </child>
        </div>
    </template>
    
    
    子组件:
    <template>
        <div class="lockInfo">
            <h3>我是是子组件</h3>
            <slot name='header'></slot>
            <slot></slot>
            <slot name='footer'></slot>
        </div>
    </template> 

页面显示

页面渲染

作用域插槽 | 带数据的插槽

最后,就是我们的作用域插槽。这个稍微难理解一点。官方叫它作用域插槽,实际上,对比前面两种插槽,我们可以叫它带数据的插槽。

在slot上面绑定数据。也就是你得写成大概下面这个样子。

<slot name="header" :data="data"></slot>
 export default {
    data: function(){
      return {
        data: ['列表1','列表2','列表3','列表4','列表5','列表6']
      }
    },
}

父组件中这样写

 <h3>这里是父组件</h3>
    <child>
      <ul slot='header' slot-scope="list">
          <li v-for="item in list.data"></li>
      </ul>
    </child> 

页面显示

页面渲染