slot 插槽
- 作用: 可以让我们在组件中书写内容
<div id="app">
<Hello>
<header> 头部 </header>
<section> 内容 </section>
<footer> 底部 </footer>
</Hello>
</div>
<template id="hello">
<div>
hello
<slot></slot>
</div>
</template>
- 具名插槽
<div id="app">
<Hello>
<header slot = "header"> 头部 </header>
<section slot = "content"> 内容 </section>
<footer slot = "footer"> 底部 </footer>
</Hello>
</div>
<template id="hello">
<div>
<slot name = "header"></slot>
<slot name = "content"></slot>
hello
<slot name = "footer"></slot>
</div>
</template>
slot 作用域插槽
- 旧: slot-scope
```javascript
Vue.component('Hello',{
template: '#hello',
data () {
return {
msg: 'hello'
}
}
})
new Vue({
el: '#app'
})
- 新: v-slot
<div id="app">
<Hello>
<template v-slot:default = "slotProp">
{{ slotProp.msg }}
</template>
</Hello>
</div>
<template id="hello">
<div>
<slot name = "default" :msg = "msg"></slot>
</div>
</template>
new Vue({
components: {
'Hello': {
template: '#hello',
data () {
return {
msg: 'hello'
}
}
}
}
}).$mount('#app')