Vue3从入门到实战:深度掌握通信插槽slot

slot_默认插槽的概念:

在Vue中,插槽(slot)是一种用于在组件中插入内容的特殊技术。默认插槽是其中一种类型的插槽,它允许你在组件的模板中指定一个位置,以便在使用组件时插入自定义的内容。

想象一下你有一个组件,它有一些固定的结构和内容,但你希望在使用这个组件时,能够灵活地插入额外的内容。这就像是你有一个模板,但你希望能够在特定的位置插入自己的文本或元素。

默认插槽就是为了满足这个需求而设计的。在组件的模板中,你可以使用 <slot></slot> 标签来标记一个位置,表示这里可以插入额外的内容。当你在使用组件时,可以将自定义的内容放置在这个位置,这样它们就会被插入到组件的对应位置上。

以一个简单的卡片组件为例,卡片的主体部分是固定的,但你希望在卡片的底部插入自己的文本或按钮。你可以在组件的模板中定义一个默认插槽,使用 <slot></slot> 标签表示插入位置。然后,在使用组件时,你可以在对应的位置插入自己的内容。

默认插槽允许你以一种灵活的方式定制组件的部分内容,使组件能够适应不同的使用场景和需求。通过使用默认插槽,你可以将一些组件的部分交给使用者来灵活控制,增加了组件的可定制性和复用性。

但需要注意的是,默认插槽可以有默认内容,即当没有提供自定义内容时,会显示默认内容。你可以在 <slot></slot> 标签中添加默认的文本或元素,这样当没有插入自定义内容时,会显示默认内容。

1_slot_默认插槽 

 1.准备一个父组件(Father.vue)

2.子组件 Category.vue

整体展示:

  

 1.父组件给子组件传标题title

 展示:

 2.在父组件定义数据,分别放入到不同标题下的内容

 3.用双组件,把每块要传入的数据会放在slot之间

 展示:

补充:

为什么要用slot插槽呢 ?

因为可以渲染不同的内容,游戏是数组,美食是图片,影视是视频

你如何把他们分别呈现在对应标题下呢,就可以用slot插槽了(其实用v-if/show也可以,但插槽更好)

不然你看下面:

 Father.vue代码:

<template>
  <div class="father">
    <h3>父组件</h3>
    <div class="content">
      <Category>
          <ul>
            <li v-for="g in games" :key="g.id">{{ g.name }}</li>
          </ul>
      
          <h2>热门游戏列表</h2>
      </Category>

      <Category>
   
          <img :src="imgUrl" alt="">
          <h2>今日美食城市</h2>
      </Category>

      <Category>
          <video video :src="videoUrl" controls></video>
          <h2>今日影视推荐</h2>
      </Category>
    </div>
  </div>
</template>

<script setup lang="ts" name="Father">
  import Category from './Category.vue'
  import { ref,reactive } from "vue";

  let games = reactive([
    {id:'asgytdfats01',name:'英雄联盟'},
    {id:'asgytdfats02',name:'王者农药'},
    {id:'asgytdfats03',name:'红色警戒'},
    {id:'asgytdfats04',name:'斗罗大陆'}
  ])
  let imgUrl = ref('https://z1.ax1x.com/2023/11/19/piNxLo4.jpg')
  let videoUrl = ref('http://clips.vorwaerts-gmbh.de/big_buck_bunny.mp4')

</script>

<style scoped>
  .father {
    background-color: rgb(165, 164, 164);
    padding: 20px;
    border-radius: 10px;
  }
  .content {
    display: flex;
    justify-content: space-evenly;
  }
  img,video {
    width: 100%;
  }
  h2 {
    background-color: orange;
    text-align: center;
    font-size: 20px;
    font-weight: 800;
  }
</style>

Category.vue代码: 

<template>
  <div class="category">
    <slot>默认内容</slot>
   
  </div>
</template>

<script setup lang="ts" name="Category">
  
</script>

<style scoped>
  .category {
    background-color: skyblue;
    border-radius: 10px;
    box-shadow: 0 0 10px;
    padding: 10px;
    width: 200px;
    height: 300px;
  }
</style>


2_slot_具名插槽 

slot_具名插槽的概念:和默认插槽没什么区别 ,只是给插槽起了个名字。

如果给 插槽起个名,

 此时<Category>没有引用s2,所以去寻找默认插槽,找不到名为s2的插槽,所以不呈现。

那如何引用呢?

1.用v-slot指令

2.将v-slot指令放在<template>中

呈现: 

 

也可以通过具名插槽来对数据进行自己想要排放好的顺序。

 

补充:

v-slot指令可以用“#”来代替 

  Father.vue代码:

<template>
  <div class="father">
    <h3>父组件</h3>
    <div class="content">
      <Category>
        <template v-slot:s2>
          <ul>
            <li v-for="g in games" :key="g.id">{{ g.name }}</li>
          </ul>
        </template>
        <template v-slot:s1>
          <h2>热门游戏列表</h2>
        </template>
      </Category>

      <Category>
        <template v-slot:s2>
          <img :src="imgUrl" alt="">
        </template>
        <template v-slot:s1>
          <h2>今日美食城市</h2>
        </template>
      </Category>

      <Category>
        <template #s2>
          <video video :src="videoUrl" controls></video>
        </template>
        <template #s1>
          <h2>今日影视推荐</h2>
        </template>
      </Category>
    </div>
  </div>
</template>

<script setup lang="ts" name="Father">
  import Category from './Category.vue'
  import { ref,reactive } from "vue";

  let games = reactive([
    {id:'asgytdfats01',name:'英雄联盟'},
    {id:'asgytdfats02',name:'王者农药'},
    {id:'asgytdfats03',name:'红色警戒'},
    {id:'asgytdfats04',name:'斗罗大陆'}
  ])
  let imgUrl = ref('https://z1.ax1x.com/2023/11/19/piNxLo4.jpg')
  let videoUrl = ref('http://clips.vorwaerts-gmbh.de/big_buck_bunny.mp4')

</script>

<style scoped>
  .father {
    background-color: rgb(165, 164, 164);
    padding: 20px;
    border-radius: 10px;
  }
  .content {
    display: flex;
    justify-content: space-evenly;
  }
  img,video {
    width: 100%;
  }
  h2 {
    background-color: orange;
    text-align: center;
    font-size: 20px;
    font-weight: 800;
  }
</style>

Category.vue代码: 

<template>
  <div class="category">
    <slot name="s1">默认内容</slot>
    <slot name="s2">默认内容</slot>
   
  </div>
</template>

<script setup lang="ts" name="Category">
  
</script>

<style scoped>
  .category {
    background-color: skyblue;
    border-radius: 10px;
    box-shadow: 0 0 10px;
    padding: 10px;
    width: 200px;
    height: 300px;
  }
</style>


3_slot_作用域插槽

slot_作用域插槽的概念: 

在Vue中,作用域插槽(scoped slot)是一种特殊的插槽技术,它允许你向组件传递数据,并在插槽内部使用这些数据。

想象一下你有一个组件,它有一个插槽,你希望能够向插槽内部传递一些数据,并在插槽内部根据这些数据进行一些处理或显示。这就像是你给一个盒子里面放入了一些物品,并允许别人在盒子里对这些物品进行操作。

作用域插槽就是为了满足这个需求而设计的。在组件的模板中,你可以使用 <slot> 标签,并在标签中添加一个特殊的属性,比如 v-slot,来定义作用域插槽。通过这个属性,你可以向插槽内部传递数据。

当你在使用组件时,可以在组件的标签中使用特殊的语法,比如 v-slot 或 slot-scope,来接收传递给插槽的数据。然后,在插槽内部,你可以使用这些数据进行一些处理、显示或其他操作。

 要想讲好作用域插槽 ,先对组件进行部分修改

1.将Category.vue组件替换成Game.vue组件

2.父组件(Father.vue)调用三次子组件(Game.vue) 

展示:

3.现在,我要将标题下的游戏内容进行如下修改
1.第一个是无序列表

2.第二个是有序列表 

3.第三个不是列表,是h3标签表示

 数据在子组件这里,但是根据数据生成的结构,却由父组件来决定。但是父组件不能直接拿到子组件的数据,这就涉及到作用域的问题,我们可以用作用域插槽来解决这个问题。


 补充:

大部分作用域插槽都是应用在UI库中,就好像UI库的作者在子组件写好了数据,你直接拿来决定数据的结构,嘿嘿嘿。

Father.vue代码:

<template>
  <div class="father">
    <h3>父组件</h3>
    <div class="content">
      <Game>
        <template v-slot="params">
          <ul>
            <li v-for="y in params.youxi" :key="y.id">
              {{ y.name }}
            </li>
          </ul>
        </template>
      </Game>

      <Game>
        <template v-slot="params">
          <ol>
            <li v-for="item in params.youxi" :key="item.id">
              {{ item.name }}
            </li>
          </ol>
        </template>
      </Game>

      <Game>
        <template #default="{youxi}">
          <h3 v-for="g in youxi" :key="g.id">{{ g.name }}</h3>
        </template>
      </Game>

    </div>
  </div>
</template>

<script setup lang="ts" name="Father">
  import Game from './Game.vue'
</script>

<style scoped>
  .father {
    background-color: rgb(165, 164, 164);
    padding: 20px;
    border-radius: 10px;
  }
  .content {
    display: flex;
    justify-content: space-evenly;
  }
  img,video {
    width: 100%;
  }
</style>

Category.vue代码:

<template>
  <div class="game">
    <h2>游戏列表</h2>
    <slot :youxi="games"></slot>
  </div>
</template>

<script setup lang="ts" name="Game">
  import {reactive} from 'vue'
  let games = reactive([
    {id:'asgytdfats01',name:'英雄联盟'},
    {id:'asgytdfats02',name:'王者农药'},
    {id:'asgytdfats03',name:'红色警戒'},
    {id:'asgytdfats04',name:'斗罗大陆'}
  ])
</script>

<style scoped>
  .game {
    width: 200px;
    height: 300px;
    background-color: skyblue;
    border-radius: 10px;
    box-shadow: 0 0 10px;
  }
  h2 {
    background-color: orange;
    text-align: center;
    font-size: 20px;
    font-weight: 800;
  }
</style>

总结:

总结起来,Vue中的插槽分为三种类型:默认插槽(Default Slot)、作用域插槽(Scoped Slot)和具名插槽(Named Slot)。

  1. 默认插槽(Default Slot):允许在组件中指定一个位置,用于插入自定义内容。可以提供默认内容,当没有自定义内容时,显示默认内容。默认插槽增加了组件的可复用性和灵活性。

  2. 作用域插槽(Scoped Slot):允许向组件传递数据,并在插槽内部使用这些数据进行处理或显示。通过作用域插槽,使用者可以将数据从组件传递到插槽内部,实现高级的定制功能。

  3. 具名插槽(Named Slot):允许在组件中定义多个命名的插槽,并通过名称来指定要插入的内容。使用具名插槽,我们可以在组件的模板中为每个插槽指定特定的名称,并在使用组件时通过特殊的语法将内容插入到指定的插槽中。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/549216.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

FOR循环指令计算累加和(CODESYS ST+SMART梯形图代码)

1、SMART PLC FOR循环指令应用 SMART PLC FOR循环指令_smart plc可以调用多少次for循环-CSDN博客文章浏览阅读2.4k次&#xff0c;点赞2次&#xff0c;收藏6次。SMART PLC的FOR循环&#xff1a; PLC里写需要加上&#xff1a; NEXT指令_smart plc可以调用多少次for循环https://r…

Tomcat下载配置地址

IntelliJ IDEA是一个强大的集成开发环境&#xff0c;能够大大简化Java应用程序的开发和部署过程。而Tomcat作为一个流行的Java Web服务器&#xff0c;其与IntelliJ IDEA的整合能够提供便捷的开发环境&#xff0c;让开发人员更专注于代码的创作与优化。 在配置IntelliJ IDEA以使…

【题解】AB5 点击消除(C++)

把string当栈用&#xff0c;扫一遍就可以了&#xff0c;时间复杂度O(n) #include <iostream> #include <string> using namespace std;int main() {string s;cin >> s;int n s.size();string st;for (int i 0; i < n; i) {if (st.empty() || st.back()…

2023年看雪安全技术峰会(公开)PPT合集(11份)

2023年看雪安全技术峰会&#xff08;公开&#xff09;PPT合集&#xff0c;共11份&#xff0c;供大家学习参阅。 1、MaginotDNS攻击&#xff1a;绕过DNS 缓存防御的马奇诺防线 2、从形式逻辑计算到神经计算&#xff1a;针对LLM角色扮演攻击的威胁分析以及防御实践 3、TheDog、0…

【Java开发指南 | 第一篇】类、对象基础概念及Java特征

读者可订阅专栏&#xff1a;Java开发指南 |【CSDN秋说】 文章目录 类、对象基础概念Java特征 Java 是一种面向对象的编程语言&#xff0c;它主要通过类和对象来组织和管理代码。 类、对象基础概念 类&#xff1a;类是一个模板&#xff0c;它描述一类对象的行为和状态。例如水…

绝地求生更新反作弊系统“ZAKYNTHOS”杀疯了

绝地求生的反作弊系统“ZAKYNTHOS”近期取得了显著的成绩。从2024年1月1日至3月3日&#xff0c;共有117,3588个违规账号被封禁&#xff0c;其中107,3317个账号因使用外挂而被永久封禁。 根据官方每周封禁数据公告&#xff0c;1月至3月每周的永久封禁违规账号平均数高达13万&am…

22 文件系统

了解了被打开的文件&#xff0c;肯定还有没被打开的文件&#xff0c;就是磁盘上的文件。先从磁盘开始认识 磁盘 概念 内存是掉电易失存储介质&#xff0c;磁盘是永久性存储介质 磁盘的种类有SSD&#xff0c;U盘&#xff0c;flash卡&#xff0c;光盘&#xff0c;磁带。磁盘是…

WPF中DataGrid主从数据(父子数据)展示

在wpf中可以使用DataGrid控件,进行主从数据展示,也称父子数据展示。下面展示纯原生控件编码实现功能(样式自己可以根据需求进行修改)。 效果如下: 点击图标,展开和收缩可以自由的切换,也可以自己重新写一个样式,比如+,-或者类似图标的样式,都是可以的。 1.首先创建一…

2024年nodejs调用小红书最新关注(粉丝)follow接口,api接口分析2004-04-16

一、打开chrome按f12&#xff0c;点击右上角的“关注”按钮&#xff0c;抓包位置如下&#xff1a; (图1 follow接口) 二、follow接口分析 1、请求地址 https://edith.xiaohongshu.com/api/sns/web/v1/user/follow 2、请求方法: POST 3、请求头&#xff1a; :authority: edith…

IO流高级流

前言 缓冲区能够提升输入输出的效率 虽然FileReader和FileWriter中也有缓冲区 但是BufferedReader和BufferWriter有两个非常好用的方法. 缓冲流 字节缓冲流 import java.io.*;public class BufferedStreamDemo {public static void main(String[] args) throws IOExceptio…

策略模式(知识点)——设计模式学习笔记

文章目录 0 概念1 使用场景2 优缺点2.1 优点2.2 缺点 3 实现方式4 和其他模式的区别5 具体例子实现5.1 实现代码 0 概念 定义&#xff1a;定义一个算法族&#xff0c;并分别封装起来。策略让算法的变化独立于它的客户&#xff08;这样就可在不修改上下文代码或其他策略的情况下…

LC 206.反转链表

# 206.反转链表 给你单链表的头节点 head &#xff0c;请你反转链表&#xff0c;并返回反转后的链表。 示例 1&#xff1a; 输入&#xff1a; head [1,2,3,4,5] 输出&#xff1a;[5,4,3,2,1] 示例 2&#xff1a; 输入&#xff1a; head [1,2] 输出&#xff1a;[2,1] 示例…

工作流引擎项目解析

API 编辑 在Camunda中&#xff0c;API的继承关系主要体现在各个服务接口之间。以下是Camunda中一些常见服务接口的继承关系&#xff1a; ProcessEngineServices 接口&#xff1a; RepositoryService&#xff1a; 负责管理流程定义和部署。 RuntimeService&#xff1a; 负责管…

《大话数据结构》01

1. 什么是数据 数据&#xff1a;是描述客观事物的符号&#xff0c;是计算机中可以操作的对象&#xff0c;是能被计算机识别&#xff0c;并输入给计算机处理的符号集合。数据不仅仅包括整型、实型等数值类型&#xff0c;还包括字符及声音、图像、视频等非数值类型。 比如我们现…

Java --- 类与对象

上篇内容给大家带来了Java的语句与数组的相关内容&#xff0c;那么本期内容比较重要&#xff0c;需要读者们掌握Java面向对象编程的根本&#xff0c;通过这篇博客来让读者浅入理解Java类的一些基本操作。 目录 一.特点&#xff1a; 二.成员变量&#xff1a; 三.访问修饰符&a…

Chatgpt掘金之旅—有爱AI商业实战篇|构建SaaS业务|(二十)

演示站点&#xff1a; https://ai.uaai.cn 对话模块 官方论坛&#xff1a; www.jingyuai.com 京娱AI 一、程序员如何搞副业构建 SAAS 业务&#xff1f; 程序员不仅拥有将抽象概念转化为实际应用的能力&#xff0c;还通常具备强大的逻辑思维和问题解决能力。然而&#xff0c;许…

读书笔记之《如何精心设计提示词来精通ChatGPT》

《如何精心设计提示词来精通ChatGPT》这本书英文标题为&#xff1a;《The Art of Prompt Engineering with chatGPT》&#xff0c;于2023年出版。作者是Nathan Hunter 。 Nathan Hunter简介&#xff1a;ChatGPT培训的创始人。作为一名资深培训师和教学设计师&#xff0c;我在过…

【MogDB】在ORACLE和MogDB中查看存储过程出参游标数据的方式

一、前言 使用ORACLE作为数据库的应用软件中&#xff0c;偶尔会遇到使用游标作为出参的存储过程&#xff0c;这种存储过程迁移到MogDB并不需要进行改造&#xff0c;但是在开发这样的存储过程时&#xff0c;开发人员偶尔会想要在数据库中测试执行一下&#xff0c;看看游标中的数…

OpenHarmony实战开发-Grid和List内拖拽交换子组件位置。

介绍 本示例分别通过onItemDrop()和onDrop()回调&#xff0c;实现子组件在Grid和List中的子组件位置交换。 效果图预览 使用说明&#xff1a; 拖拽Grid中子组件&#xff0c;到目标Grid子组件位置&#xff0c;进行两者位置互换。拖拽List中子组件&#xff0c;到目标List子组件…

MongoDB的go SDK使用集锦

在上一章解读MongoDB官方文档获取mongo7.0版本的安装步骤与基本使用介绍了如何使用mongo shell操作mongo数据库&#xff0c;接下来介绍如何使用sdk来操作数据库&#xff0c;这里以go语言为例&#xff0c;其他语言请查看源文档mongo docs Quick Start 内置数据结构 MongoDB是存…