插槽只能获取当前组件的作用域
默认插槽
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Document</title>
<script src="../vue.global.js"></script>
</head>
<body>
<div id="app">
<!-- 默认插槽 -->
<my-head>
<p>{{message}}</p>
</my-head>
</div>
<script>
let app = Vue.createApp({
data() {
return {
message: "朱朱",
};
},
});
//子组件
app.component("MyHead", {
template: `
<slot></slot>
`,
});
let vm = app.mount("#app");
</script>
</body>
</html>
具名插槽
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Document</title>
<script src="../vue.global.js"></script>
</head>
<body>
<div id="app">
<!-- 具名插槽 -->
<my-head>
<template v-slot:title>
<p>{{message}}</p>
</template>
<template v-slot:list>
<ul>
<li>吃饭</li>
<li>还是吃饭</li>
<li>继续干饭</li>
</ul>
</template>
</my-head>
</div>
<script>
let app = Vue.createApp({
data() {
return {
message: "朱朱",
};
},
});
app.component("MyHead", {
template: `
<slot name='title'></slot>
<slot name='list'></slot>
`,
});
let vm = app.mount("#app");
</script>
</body>
</html>
补充
//vue2 v-slot可以简写为slot
//但是v-slot只配合template使用
//slot可以配合template和html元素
//但是在vue3里面只能是v-slot:'title'或者#title
<template slot="title">
<p>{{message}}</p>
</template>
//也可以这样 具体看自己的需求
<p slot="title">{{message}}</p>
作用域插槽
div id="app">
<!-- 具名插槽 -->
<my-head>
//<template scope="{list}">或者
<template slot-scope="{list}">
<ul>
<li v-for='(item,index) in list' :key='item'>{{item}}</li>
</ul>
</template>
</my-head>
</div>
<script>
let app = Vue.createApp({
data() {
return {
message: "朱朱",
};
},
});
app.component("MyHead", {
data() {
return {
list: ["吃饭", "睡觉"],
};
},
template: `
<slot :list='list'></slot>
`,
});