深入理解vue插槽

news2024/12/22 19:44:08

我们都知道vue的插槽及使用,一下是探究他的背后,不对的地方欢迎指正

父组件中我们在子组件中嵌套插槽,在子组件中我们使用template模板写下对应的插槽

实际上父组件中经过编译传递给子组件的插槽是函数

此图为下面示例中子组件中的输出

default是默认插槽

footer是传的动态插槽

head是传的作用域插槽

title是传的具名插槽
在这里插入图片描述
然后 我们在子组件中 通过调用 slots.xxx 即插槽的名字 返回的是对应的虚拟dom,(数据结构之所以是数组对象 因为插槽中的节点可能是多个 )
在这里插入图片描述
此时 我们调用 vue的 创建dom方法 createElementVNode

最终的效果是和 template 写出来的一样的
在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
 
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>深入理解vue插槽</title>
  <script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>
</head>
 
<body>
  <div id="app"></div>
 
  <script>
    const { createApp, createElementVNode } = Vue
    const app = createApp({
      template: `
        <parent-component></parent-component>
      `
    })
 
    app.component('parent-component', {
      setup () {
        const dynamicSlot = Vue.ref('footer')
        return { dynamicSlot }
      },
      template: `
        <div>
          <child-component :slotName="dynamicSlot">
            <template #default>
              <p>默认插槽</p>
            </template>
            <template #head="{ message }">
              <h1>作用域插槽----{{ message }}</h1>
            </template>
            <template #title>
              <p>具名插槽</p>
            </template>
            <template #[dynamicSlot]>
              <p>动态插槽</p>
            </template>
          </child-component>
        </div>
      `
    })
 
    app.component('child-component', {
      props:{
        slotName:{
          type:String
        }
      },
      setup (props, { slots }) {
        console.log(slots, 'slots--',props)
        const _default = slots.default()
        const head = slots.head({ message: '你好' })
        const title = slots.title()
        const propslotName = slots[props.slotName]()
        console.log(_default,head,title,propslotName)
        return () => {
          return createElementVNode('div', null, [
            ..._default, ...head, ...title, ...propslotName
          ])
        }
 
      },
      /* template: `
        <div>
 
          <slot></slot>
 
          <slot name="head" :message="'你好'"></slot>
 
          <slot name="title"></slot>
 
          <slot :name="slotName"></slot>
        </div>
      ` */
    })
 
    app.mount('#app')
  </script>
 
</body>
 
</html>

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

VSCode--Config

1. basic 1.1 调整字体 1.2 调整 remote login 输入框都在 TERMINAL 中实现 1.3 界面设置成中文 安装插件&#xff1a; 然后配置即可。 2.Linux 2.1 Install 2.1.1 offline Install vscode server 问题描述 内网开发&#xff0c;vscode 自身通过代理安装完 remote 插件后…

【算法系列之二叉树IV】leetcode450.删除二叉搜索树中的节点

701.二叉搜索树中的插入操作 力扣题目链接 给定二叉搜索树&#xff08;BST&#xff09;的根节点 root 和要插入树中的值 value &#xff0c;将值插入二叉搜索树。 返回插入后二叉搜索树的根节点。 输入数据 保证 &#xff0c;新值和原始二叉搜索树中的任意节点值都不同。 注…

shell之免交互

一.免交互&#xff08;Here Document&#xff09;介绍 使用I/O重定向的方式将命令列表提供给交互式程序或命令&#xff0c;比如 ftp、cat 或 read 命令。是标准输入的一种替代品可以帮助脚本开发人员不必使用临时文件来构建输入信息&#xff0c;而是直接就地生产出一个“文件”…

chatgpt赋能python:Python在主程序中进行函数调用

Python在主程序中进行函数调用 介绍 Python是一种广泛使用的高级编程语言&#xff0c;它在创建Web应用程序、网络服务器、数据分析、机器学习等多个领域中表现出色。在Python中&#xff0c;函数是编程中最重要的概念之一&#xff0c;函数调用是指程序员在主程序中调用一个或多…

系统移植-uboot

目录 一、安装系统 1.移植的目的 2.系统移植过程 Windows装机 Linux系统移植 3.开发板启动过程 二、Uboot概述 1.Bootloader简介 Bootloader基本功能 uboot工作方式 三、SD卡存储结构 一、安装系统 在基于ARM处理器的开发板上安装Linux系统 1.移植的目的 不…

docker版jxTMS使用指南:python服务之设备策略

本文讲解4.0版的jxTMS中python服务的设备策略&#xff0c;整个系列的文章请查看&#xff1a;docker版jxTMS使用指南&#xff1a;4.0版升级内容 docker版本的使用&#xff0c;请参考&#xff1a;docker版jxTMS使用指南 jxTMS实现的接口机对设备的数据采集与处理采取的是框架组…

Elastic Stack 和 Docker-Compose 入门

作者&#xff1a;Eddie Mitchell 随着 Elastic Stack 多年来的发展和功能集的增加&#xff0c;在本地开始或尝试概念验证 (POC) 的复杂性也越来越高。 虽然 Elastic Cloud 仍然是开始使用 Elastic 最快、最简单的方式&#xff0c;但对本地开发和测试的需求仍然非常丰富。 作为开…

【生成任务下推生成子工序生产计划,无法结单】

今天&#xff0c;车间反馈了一个问题&#xff0c;bpm结单报错。 原先定的流程是&#xff0c;生产任务单审批流程走完之后&#xff0c;下推到MES&#xff0c;生产子工序生产计划。 这个审批流最后要到制品&#xff0c;这个工单做完了&#xff0c;制品也包装好了&#xff0c;流程…

用于改进筛查的乳腺癌异常检测

介绍 乳腺癌是一种严重的疾病&#xff0c;影响着全世界数以百万计的妇女。即使医学领域有了进步&#xff0c;对乳腺癌进行识别和治疗是可能的&#xff0c;但发现它并在早期阶段治疗它仍然是不可能的。 通过使用异常检测技术&#xff0c;我们可以识别出乳腺癌中肉眼可能看不到的…

STM32——关于EXTI讲解及标准库应用(基础篇)

简介&#xff1a; STM32的中断包括EXTI外部中断、TIM定时器、ADC模数转换器、USART串口&#xff0c;SPI通信、I2C通信等一系列的外设。这篇主要来讲解关于EXTI外部中断的概念和应用。EXTI&#xff08;External Interrupt&#xff09;是一个非常重要的外部中断模块&#xff0c;…

chatgpt赋能python:Python多条图形绘制在一张图里的实现方法及应用

Python多条图形绘制在一张图里的实现方法及应用 作为一款优秀的编程语言&#xff0c;Python在数据可视化方面有着非常出色的表现。然而有时候我们需要在一张图里绘制多条不同的图形&#xff0c;这时候Python又有什么好的解决方案呢&#xff1f;本文将介绍多种方法实现Python在…

10个最流行的可生成图像嵌入向量的预训练AI模型

迁移学习的出现进一步加速了计算机视觉——图像分类用例的快速发展。 在大型图像数据集上训练计算机视觉神经网络模型需要大量的计算资源和时间。 幸运的是&#xff0c;通过使用预训练模型可以缩短时间和资源。 利用预训练模型的特征表示的技术称为迁移学习。 预训练通常使用高…

《MySQL(三):基础篇- 函数》

文章目录 3. 函数3.1 字符串函数3.2 数值函数3.3 日期函数3.4 流程函数 3. 函数 函数 是指一段可以直接被另一段程序调用的程序或代码。 也就意味着&#xff0c;这一段程序或代码在MySQL中 已经给我们提供了&#xff0c;我们要做的就是在合适的业务场景调用对应的函数完成对应…

Vue.js 中的响应式原理是什么?

Vue.js 中的响应式原理是什么&#xff1f; Vue.js 是一种流行的前端框架&#xff0c;它使用了一种称为“响应式”的技术来实现数据绑定。这意味着当数据发生变化时&#xff0c;Vue.js会自动更新相关的视图&#xff0c;而无需手动操作DOM。在本文中&#xff0c;我们将深入探讨V…

【SCI征稿】Elsevier旗下中科院2区TOP, 仅1周见刊, 6月11日截稿 (文末有好)~

一、【期刊简介】 中科院2区智能计算类SCI (TOP/6.11截稿) 【期刊概况】IF:8.0-9.0, JCR1区, 中科院2区&#xff1b; 【终审周期】走期刊部系统&#xff0c;3-5个月左右录用&#xff1b; 【检索情况】SCI&EI双检&#xff1b;正刊&#xff1b; 【数据库收录年份】2001年…

RHCE练习题目【更新至】

文章目录 第一题、安装和配置ansible第二题、创建和运行ansible临时命令第三题、使用剧本安装软件包第四题、使用RHEL系统脚色第一问、配置时间同步第二问、配置selinux 第五题、使用Ansible Galaxy安装角色第六题、创建和使用角色第七题、从Ansible Galaxy使用角色第八题、创建…

一文搞定国民N32G435高负载串口通信

副标题&#xff1a;USRAT无硬件双缓冲条件下的软件双缓冲 一、前言 在单片机中&#xff0c;USART的通信一般都是最常用也最先去接触的串口外设&#xff0c;在一般的小数据量应用中一般不需要考虑USART串口&#xff08;以下简称为串口&#xff09;的高负载能力&#xff0c;比如…

第六十五天学习记录:高等数学:函数与极限(宋浩板书)

C语言学习后&#xff0c;曾为先学C还是数据结构纠结了半天。在看数据结构前言的时候&#xff0c;发现学习数据结构之前还需要一定的数学基础。虽然涉及到的数学基础不多&#xff0c;但想到以前大学高数&#xff0c;现代不是60分万岁就是不到80分&#xff0c;好像就概率论稍微了…

【Python】Python系列教程-- Python3 循环语句(十七)

文章目录 前言while 循环无限循环while 循环使用 else 语句简单语句组for 语句for...elserange() 函数break 和 continue 语句及循环中的 else 子句pass 语句 前言 往期回顾&#xff1a; Python系列教程–Python3介绍&#xff08;一&#xff09;Python系列教程–Python3 环境…

Treap C++代码实现

一、全部代码 #include <iostream> #include <cstdlib> #include <time.h>using namespace std;//Treap结构 struct TreapNode {TreapNode *pLeft, *pRight;int value, fix; };//左旋 void TreapLeftRotate(TreapNode* &pCur){//首先&#xff0c;找到当…