vue组件详解之使用slot分发内容

2020-06-13 10:37:33易采站长站整理

一、什么是slot

在使用组件时,我们常常要像这样组合它们:


<app>
<app-header></app-header>
<app-footer></app-footer>
</app>

当需要让组件组合使用,混合父组件的内容与子组件的模板时,就会用到slot , 这个过程叫作内容分发( transclusion )。

注意两点:

1.< app>组件不知道它的挂载点会有什么内容。挂载点的内容是由<app >的父组件决定的。

2.<app> 组件很可能有它自己的模板。

props 传递数据、events 触发事件和slot 内容分发就构成了Vue 组件的3 个API 来源,再复杂的组件也是由这3 部分构成的。

 二、作用域


<child-component>
{{ message }}
</child-component>

这里的message 就是一个slot ,但是它绑定的是父组件的数据,而不是组件<child-component>的数据。

父组件模板的内容是在父组件作用域内编译,子组件模板的内容是在子组件作用域内编译。如:


<div id="app15">
<child-component v-show="showChild"></child-component>
</div>
Vue.component('child-component',{
template: '<div>子组件</div>'
});
var app15 = new Vue({
el: '#app15',
data: {
showChild: true
}
});

这里的状态showChild 绑定的是父组件的数据,如果想在子组件上绑定,那应该是:


<div id="app15">
<child-component></child-component>
</div>
Vue.component('child-component',{
template: '<div v-show="showChild">子组件</div>',
data: function(){
return {
showChild: true
}
}
});

因此, slot 分发的内容,作用域是在父组件上的。

三、slot用法

3.1 单个slot

在子组件内使用特殊的<slot>元素就可以为这个子组件开启一个slot(插槽),在父组件模板里,插入在子组件标签内的所有内容将替代子组件的<slot> 标签及它的内容。   


<div id="app16">
<my-component16>
<p>分发的内容</p>
<p>更多分发的内容</p>
</my-component16>
</div>
Vue.component('my-component16',{
template: '<div>' +
'<slot><p>如果父组件没有插入内容,我将作为默认出现<</p></slot>' +    //预留的slot插槽
'</div>'