1. 概述

非理性定律告诉我们:

人们总是习惯于以情感去判断眼前的事物,非理性的去做决定。

对于长远的利益,人们更愿意去选择短期的利益。

因此在做决定前要让自己冷静,理性的分析,让自己看的更远。

言归正传,今天我们来聊一个新的概念 —— 插槽。

2. 插槽的使用

2.1 一个简单的例子

我们先来看一个简单的例子

<body>
<div id="myDiv"></div>
</body>
<script> const app = Vue.createApp({
template:`
<div>
<my-form />
</div>
`
});
app.component("my-form", {
methods:{
myClick() {
alert('提交');
}
},
template: `
<div>
<input />
<button @click="myClick">提交</button>
</div>
`
});
const vm = app.mount("#myDiv");

这个例子很简单,我们在子组件中写了一个文本框,文本框的后面是一个按钮,点击按钮会 alert 一个提示

2.2 父组件决定按钮的样式

如果我们希望子组件更灵活、复用性更强,子组件按钮的样式可以由父组件去改变,该怎样做呢,我们看下面的例子

    const app = Vue.createApp({
template:`
<div>
<my-form>
<div>提交</div>
</my-form>
<my-form>
<button>提交</button>
</my-form>
</div>
`
}); app.component("my-form", {
methods:{
myClick() {
alert('提交');
}
},
template: `
<div>
<input />
<slot @click="myClick"></slot>
</div>
`
});

这里我们使用了插槽(slot)的概念,父组件使用子组件时,组件标签中间的部分就是插槽的内容,

例如:<my-form><div>提交</div></my-form> 中,<div>提交</div> 就是插槽的内容

子组件定义时,可以使用 <slot /> 获取到父组件定义的插槽的内容

这个例子中,父组件使用了两次 my-form 子组件,但按钮的样式是不同的。

但这个例子中有一个问题,我们会发现点击【提交】按钮没有任何效果,这是因为 slot 标签是不能直接绑定事件的,下面我们来解决这个问题

2.3 插槽绑定事件

slot 标签不能直接绑定事件,通常的做法是在外层加一个 span 标签,然后把事件绑定到 span 标签上

    const app = Vue.createApp({
template:`
<div>
<my-form>
<div>提交</div>
</my-form>
<my-form>
<button>提交</button>
</my-form>
</div>
`
}); app.component("my-form", {
methods:{
myClick() {
alert('提交');
}
},
template: `
<div>
<input />
<span @click="myClick">
<slot></slot>
</span>
</div>
`
});

2.4 子组件作为插槽的内容

插槽的内容,可以是普通标签、普通字符串,也可以是其他的子组件

    const app = Vue.createApp({
template:`
<div>
<my-form>
<my-button />
</my-form>
</div>
`
}); app.component("my-button", {
template: `
<div>my-button组件按钮</div>
`
}); app.component("my-form", {
methods:{
myClick() {
alert('提交');
}
},
template: `
<div>
<input />
<span @click="myClick">
<slot></slot>
</span>
</div>
`
});

这个例子中,我们在 my-button 组件中定义了一个 div按钮,然后在父组件中把 <my-button /> 作为插槽的内容,VUE 是支持的

2.5 插槽中使用数据

插槽中也是可以使用数据的

    const app = Vue.createApp({
data() {
return {
buttonName : '提交'
}
},
template:`
<div>
<my-form>
<div>{{buttonName}}</div>
</my-form>
<my-form>
<button>{{buttonName}}</button>
</my-form>
</div>
`
});
app.component("my-form", { methods:{
myClick() {
alert('提交');
}
},
template: `
<div>
<input />
<span @click="myClick">
<slot></slot>
</span>
</div>
`
});

这个例子中,插槽内容中的按钮的名称,取自父组件的数据 buttonName

注意:父组件中的插槽内容使用的是父组件的数据,而不是子组件的数据。也就是说,插槽的机制是:先用数据替换好插槽内容后,再传到子组件。

2.6 插槽的默认值

如果父组件想省事,不想指定子组件的按钮样式,此时,就需要我们指定插槽的默认内容

    const app = Vue.createApp({
data() {
return {
buttonName : '提交'
}
},
template:`
<div>
<my-form />
</div>
`
});
app.component("my-form", { methods:{
myClick() {
alert('提交');
}
},
template: `
<div>
<input />
<span @click="myClick">
<slot>默认提交按钮</slot>
</span>
</div>
`
});

指定插槽的默认内容很简单,在子组件的 slot 标签中间, 写上默认内容即可,当父组件不指定插槽内容时,则使用该内容作为插槽内容

2.7 具名插槽

如果子组件分为 header、main、footer 3个部分,header 和 footer 由父组件决定,header 放在 main 的上方, footer 放在 main 组件的下方,该如何做呢,看下面的例子

    const app = Vue.createApp({
data() {
return {
buttonName : '提交'
}
},
template:`
<div>
<my-html>
<template v-slot:header>
<div>header</div>
</template>
<template v-slot:footer>
<div>footer</div>
</template>
</my-html>
</div>
`
}); app.component("my-html", { methods:{
myClick() {
alert('提交');
}
},
template: `
<div>
<slot name="header" />
<div>main</div>
<slot name="footer" />
</div>
`
});

首先,父组件使用子组件时,使用 template 标签包住 header 的内容,在 template 标签中使用 v-slot:header 为该部分插槽命名。

子组件中,使用 <slot name="header" /> 指定插槽的位置。

footer 部分类似

3. 综述

今天聊了一下 VUE3 的 插槽的使用,希望可以对大家的工作有所帮助,下一节我们继续讲组件的相关知识,敬请期待

欢迎帮忙点赞、评论、转发、加关注 :)

关注追风人聊Java,每天更新Java干货。

4. 个人公众号

追风人聊Java,欢迎大家关注

VUE3 之 插槽的使用 - 这个系列的教程通俗易懂,适合新手的更多相关文章

  1. VUE3 之 作用域插槽 - 这个系列的教程通俗易懂,适合新手

    1. 概述 破窗效应告诉我们: 当一个建筑物窗户的玻璃完好无损时,很少有人想去破坏它,当有一个人破坏了一块窗户的玻璃,其他窗户的玻璃也很快会被人破坏. 同理,一个很干净的地方,人们不好意思去丢垃圾,但 ...

  2. VUE3 之 多个 v-model 绑定及 v-model 修饰符的使用 - 这个系列的教程通俗易懂,适合新手

    1. 概述 洛克定律告诉我们: 当我们的目标很远大,远到我们都看不到终点时,放弃几率就会很大,就像跑马拉松比赛,由于时间长.距离长,很多选手都会选择在中途放弃. 其实有个好办法,就是拆分,把大目标拆分 ...

  3. VUE3 之 动态组件 - 这个系列的教程通俗易懂,适合新手

    1. 概述 暗示效应告诉我们: 巧妙的暗示会在不知不觉中剥夺我们的判断力,对我们的思维形成一定的影响,造成我们行为的些许改变或者偏差. 例如你的朋友说你脸色不太好,是不是病了,此时,你可能就会感觉浑身 ...

  4. VUE3 之 ref、provide、inject 的使用 - 这个系列的教程通俗易懂,适合新手

    1. 概述 首因效应告诉我们: 在日常交往中,第一印象是非常重要的,好的第一印象能让我们在与人相处时事半功倍. 但也从另一面告诉我们,不能仅凭第一印象去判断一个人,有时虚假的第一印象,也有可能蒙蔽我们 ...

  5. VUE3 之 动画与过渡的实现 - 这个系列的教程通俗易懂,适合新手

    1. 概述 光环效应告诉我们: 当一个人在某一方面取得了巨大的成功,人们就会给他贴上正面的标签,这个人从此就被"优秀"的光环所笼罩,他做的一切,人们都认为是正确的. 例如:越是名气 ...

  6. VUE3 之 使用标签实现动画与过渡效果 - 这个系列的教程通俗易懂,适合新手

    1. 概述 巴纳姆效应告诉我们: 人们更容易相信笼统的.常见的人格描述,并觉得特别适合自己,认为该描述真实地反映了自己的人格面貌. 这也是所有算命先生的小把戏,算命先生通常把话说的很笼统,很通用,基本 ...

  7. VUE3 之 使用标签实现动画与过渡效果(下) - 这个系列的教程通俗易懂,适合新手

    1. 概述 毛毛虫效应: 有这样一个实验,将许多毛毛虫放在一个花盆边缘,使它们首尾相接,围成一个圈.然后在离花盆很近的地方撒了一些毛毛虫的食物. 此时,毛毛虫并不会向食物的方向爬去,而是在花盆边缘,一 ...

  8. VUE3 之 多个元素之间的过渡 - 这个系列的教程通俗易懂,适合新手

    1. 概述 老话说的好:过去不等于未来,过去成功了不代表将来也会成功,过去失败了也不代表将来也会失败. 言归正传,今天我们聊聊多个元素之间的过渡. 2. 多个元素之间的过渡 2.1 两个元素交替显示 ...

  9. VUE3 之 列表动画 - 这个系列的教程通俗易懂,适合新手

    1. 概述 老话说的好:可以为别人解决痛点的产品就是好产品. 言归正传,今天我们来聊聊 VUE 的列表动画. 2. 列表动画 2.1  列表中增加和删除元素 <style> .my-ite ...

随机推荐

  1. 【LeetCode】485. Max Consecutive Ones 解题报告(Java & Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 Java解法 Python解法 日期 [LeetCo ...

  2. 【LeetCode】275. H-Index II 解题报告(Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 题目地址: https://leetcode.com/problems/h-index- ...

  3. 【LeetCode】451. Sort Characters By Frequency 解题报告(Python & C++)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 字典 优先级队列 排序 日期 题目地址:https: ...

  4. Spring MVC 文件上传、Restful、表单校验框架

    目录 文件上传 Restful Restful 简介 Rest 行为常用约定方式 Restful开发入门 表单校验框架 表单校验框架介绍 快速入门 多规则校验 嵌套校验 分组校验 综合案例 实用校验范 ...

  5. 图片 Augmentation整理

    目录 Augmentation Flipping 翻转 Grayscale Equalize 均衡直方图 Posterize 减少颜色通道位数 Cropping Rotation Translatio ...

  6. Java初学者作业——编写 Java 程序,用户输入 3 个操作数,分别求出最大值、最小值和平均值。

    返回本章节 返回作业目录 需求说明: 编写 Java 程序,用户输入 3 个操作数,分别求出最大值.最小值和平均值. 实现思路: 定义 Java 类,定义 3 个方法,用来求 3 个数字的最大值.最小 ...

  7. Fences桌面图标分类

    1.简介 Fences也称为栅栏桌面, 可以用来分类和组织桌面上的图标. Fences可以将不同的图标放到不同的容器当中, 还可以自由的设置这个容器,比如移动和拉伸等等. 这样图标分类后,桌面就整洁多 ...

  8. CSS基础 定位相关属性的使用方法

    1.相对定位:position:relative: 属性名:position 属性值:relative: 特点:1.相对自己的位置移动 2.配合方位名词移动,如:top.left.right,bott ...

  9. TypeScript 中文教程之缩小----部分翻译自TS官方

    Narrowing概念:字面意思是缩小,可以理解为细化或者您觉得更好的代名词. TS官方在这里做了很详细的说明,文字较多,简单以图片概括: typeof  type guards 类型防护过程,可以通 ...

  10. MongoDB学习 - 安装部署

    1. docker 启动 拉取镜像 docker pull mongo:latest 指定目录启动  docker run -d -p 27017:27017 --name mongo \-v /ho ...