【Vue2】动态组件的使用-切换组件和keep-alive,以及异步组件
目录
- 想实现切换不同列表展示不同数据
- 方法一
- 方法二,动态组件
- 动态组件的父组件如何传的值
- 动态组件的子组件如何接受传的值
- 认识keep-alive
- 缓存组件的生命周期
- 异步组件,单独打包,实现webpack分包,
- 如何对组件进行单独打包,目的缓解首页加载速度
- 解决方法 异步组件
- 代码分包默认打包过程
想实现切换不同列表展示不同数据
方法一
- 通过v-if判断逻辑。负责显示哪个
- 缺点:当有大量逻辑判断的时候不推荐
<template><div class="home"><div class="nev"><divclass="nevbar":class="nevindex == index ? 'newnev' : ''"v-for="(item, index) in tab":key="index"@click="itemClick(index)">{{ item }}</div></div><one v-if="nevindex==0"></one><two v-if="nevindex==1"></two><three v-if="nevindex==2"></three></div>
</template><script>
import one from "../components/one.vue";
import two from "../components/two.vue";
import three from "../components/three.vue";
export default {name: "HomeView",components: {one,two,three,},data() {return {tab: ["列表1", "列表2", "列表3"],nevindex: 0,};},methods: {// nev切换itemClick(index) {this.nevindex = index;},},created() {},
};
</script>
<style scoped lang="scss">
.nev {display: flex;justify-content: space-around;
}
.newnev {color: aqua;
}
</style>

方法二,动态组件
- 1.功能类似于tab组件,可用于组件的切换
- 2.is属性决定了component当前渲染的组件,is属性可以是组件或者是字符串,当是字符串时代表组件的注册名称或者是标签名
- 3.component动态组件上可以传任意参数和事件,且会被所有is上的当前组件所接收
- 简单的说,component就像一个容器,根据is属性来决定渲染什么组件,其他的没有什么区别
<template><div class="home"><div class="nev"><divclass="nevbar":class="nevindex == index ? 'newnev' : ''"v-for="(item, index) in tab":key="index"@click="itemClick(index)">{{ item }}</div></div><div><component :is="tabsIndex[nevindex]"></component></div></div>
</template><script>
import one from "../components/one.vue";
import two from "../components/two.vue";
import three from "../components/three.vue";
export default {name: "HomeView",components: {one,two,three,},data() {return {tab: ["列表1", "列表2", "列表3"],tabsIndex: ["one", "two", "three"],nevindex: 0,ISshow: "one",};},methods: {// nev切换itemClick(index) {this.nevindex = index;},},created() {},
};
</script>
<style scoped lang="scss">
.nev {display: flex;justify-content: space-around;
}
.newnev {color: aqua;
}
</style>
动态组件的父组件如何传的值
<componentname="乞力马扎罗"@getClick="getClick":is="tabsIndex[nevindex]"
></component>//js中methods: {//子组件传的值getClick(e) {console.log(e);},},
动态组件的子组件如何接受传的值
<template><div><h2>one页面{{name}}</h2><button @click="handClick">子组件</button></div>
</template>
<script>
export default {props:{name:{type:String,default:''}},methods:{handClick(){this.$emit('getClick',"接受到了子组件的值")},}
}
</script>
认识keep-alive
- v-if切换这些,都会造成组件的销毁,会在这里监听到
//组件卸载unmounted(){},
- 缺点,数据的状态未保存
- 保持存活,用keep-alive包裹即可
- keep-alive有一些属性
- 1,include存放的name是组件自身的name属性,只有名称匹配的组件会被缓存
- 2,exclude,任何名称匹配的组件都不会被缓存
- 3,max,最多可以缓存多少组件实例,一旦达到这个数字,那么缓存组件中最近没有被缓存的实例会被销毁
- 以下是三种写法
//字符串<keep-alive include="homeone,hometwo"><componentname="乞力马扎罗"@getClick="getClick":is="tabsIndex[nevindex]"></component></keep-alive>//正则<keep-alive :include="/homeone|hometwo/"><componentname="乞力马扎罗"@getClick="getClick":is="tabsIndex[nevindex]"></component></keep-alive>//数组<keep-alive :include="['homeone', 'hometwo']"><componentname="乞力马扎罗"@getClick="getClick":is="tabsIndex[nevindex]"></component></keep-alive>

缓存组件的生命周期
- 该组件内部
//缓存组件的生命周期,进入活跃状态activated(){console.log("活跃")},//离开deactivated(){console.log("离开")}
异步组件,单独打包,实现webpack分包,

如何对组件进行单独打包,目的缓解首页加载速度
解决方法 异步组件
- vue中,通过vue提供的函数,defineAsyncComponent
- import函数可以让webpack对导入文件进行分包处理
- 目的:是可以对其进行分包处理
- 步骤:
//异步组件
import {defineAsyncComponent} from 'vue'
//工厂函数写法,返回promise对象
const threevue=defineAsyncComponent(()=>import("../components/three.vue"))

- npm run build

代码分包默认打包过程
- 默认情况下,构建整个组件树的过程中,因为组件和组件之间是通过模块化直接依赖的,那么wbpack在打包时候就会将组件模块打包在一起
- 这个时候随着项目的不断变大,app.js文件的内容过大,会造成首屏的渲染速度变慢
- 打包时,代码的分包
- 对于一些不需要立即使用的组件,可以单独对他们进行拆分,拆分成一些小的代码块chunk.js
- 这些chuck.js会在需要时从服务器加载下来,并且运行代码
相关文章:
【Vue2】动态组件的使用-切换组件和keep-alive,以及异步组件
目录 想实现切换不同列表展示不同数据方法一方法二,动态组件动态组件的父组件如何传的值动态组件的子组件如何接受传的值 认识keep-alive缓存组件的生命周期 异步组件,单独打包,实现webpack分包,如何对组件进行单独打包࿰…...
C++的IO流
目录 C语言的输入与输出 流是什么 CIO流 C标准IO流 C文件IO流 stringstream的简单介绍 在C语言中,如果想要将一个整形变量的数据转化为字符串格式,如何去做? 将数值类型数据格式化为字符串 字符串拼接 序列化和反序列化结构数据 注…...
nodejs+vue+elementui电影订票网站系统_wqc3k
电影订票系统在国内有很多值得借鉴的例子,功能也都趋于完善,因此此次电影订票系统将轻量化开发,要完成以下功能: (1)要支持完整的用户注册,登录功能,账号的管理通过管理员来实现。 &…...
2023-08-14 linux 串口终端输入长命令不换行,覆盖前面内容,stty命令设置串口终端行列数
一、linux 串口终端输入长命令不换行,覆盖前面内容,现象如下图: 二、解决方法:用stty 命令设置行列数 stty columns 200 stty rows 10三、参考文章 https://www.cnblogs.com/goloving/p/15170537.html 常用Linux串口设备操作命…...
根据指定日期获取周,月,季度,年的第一天和最后一天
1. 根据指定日期获取周,月,季度,年的第一天和最后一天 import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.Date;/*** 根据给定时间获取周、月度、季度、年度开始结束时间*…...
CRMEB商城系统:便捷、安全、多样化的购物方式
商城系统是当今社会商业发展的重要组成部分,它以数字化、网络化的方式提供商品和服务。商城系统通过互联网技术,将商品和消费者紧密连接,方便了购物的流程和效率。 商城系统的特点之一是无国界化。传统实体商店通常受限于地理位置和时间&…...
同步_异步请求和Ajax并利用axios框架简化
目录 同步和异步 原生的Ajax 创建XMLHttpRequest对象 常用方法 常用属性 axios框架 同步和异步 同步请求:发送请求后,会做出回应,回应的内容会覆盖浏览器中的内容,这样会打断其他正常的操作,显得不太友好&#…...
取个对象值导致系统崩溃
取个对象值导致系统崩溃 前言 想必各位小伙经常在项目中遇到一些错误,取对象值的时候,经常报错,又或者某些项目突然就挂经常都是出现在一些对象取值上面,然后就被领导一顿训斥 报错分析 例如: 下面这个报错大家想必不会陌生&am…...
nestjs 基础、使用 passport 来进行鉴权
回顾一些定义 NestJS 部分 Module 模块结构 模块是一个图状引用关系。 模块的实例化有三种模式。默认情况是 singletones 模式,也就是模块可能被引用,但不同的引用处拿的是同一个共享实例,也就是说一个进程有一个唯一的实例被共享。 模块&a…...
1.1 : DNA 螺旋
概述 脱氧核糖核酸(DNA)是负责在所有生物体和大多数病毒中代代相传性状的遗传物质。DNA由两条相互缠绕形成双螺旋的核苷酸链组成。DNA 结构的发现是在近一个世纪的时间里逐步发现的,代表了科学史上最著名、最迷人的故事之一。 DNA 结构详细信息 每条 DNA 链均由称为核苷酸…...
.gitignore匹配规则
目录 1.直接一个名称2.斜杠 /3.符号 *4.问号 ?5.感叹号 !6.gitkeep 借鉴抖音账号: 渡一前端提薪课 1.直接一个名称 会忽略目录下的所有该名称文件和文件夹,无论嵌套多深。 2.斜杠 / 1.斜杠在开头(/dist):忽略和.gitig…...
Python-OpenCV中的图像处理-GrabCut算法交互式前景提取
Python-OpenCV中的图像处理-GrabCut算法交互式前景提取 Python-OpenCV中的图像处理-GrabCut算法交互式前景提取 Python-OpenCV中的图像处理-GrabCut算法交互式前景提取 cv2.grabCut(img: Mat, mask: typing.Optional[Mat], rect, bgdModel, fgdModel, iterCount, mode…) img…...
JAVA 鼠标控制与键盘输入控制
核心类:java.awt.Robot 该类是JDK定义的电脑系统的抽象类,可以用来模拟实现鼠标点击与键盘输入等信息 简单实现一个自动抢票代码: Robot rt new Robot();//可以认为是操作间隔的停歇时间,比如等待页面加载,等弹框内容展示等 r…...
VB+SQL宿舍管理系统设计与实现
摘要 统是采用Visual Basic作为前台开发工具,SQL Server作为后台数据库平台的基于C/S的两层模式的管理系统。宿舍管理系统是目前各所高校后勤管理之中的重要部分,如何能科学有效的开展好宿舍管理部分的工作,是当前高校领导人和后勤管理人员关心的问题。因此,宿舍管理部分工…...
自律人生:戒断视频、游戏、小说、躺在床上不玩手机、睡觉前总结和冥想(提升注意力、专注度)
以下是一些方法来戒断视频、游戏、小说、躺在床上不玩手机,以及提高注意力和专注力。 制定计划 制定一个详细的计划,包括要戒断的东西、时间表以及对于成功戒断的奖励。这将帮助你保持目标,让你更容易达到成功。 找到替代品 尝试找到其他…...
学习笔记十四:K8S最小调度单元POD概述
K8S最小调度单元POD概述 k8s核心资源Pod介绍Pod是什么Pod如何管理多个容器Pod网络Pod存储代码自动发版更新收集业务日志 Pod工作方式自主式Pod控制器管理的Pod(防误删除) 如何基于Pod运行应用 k8s核心资源Pod介绍 K8s官方文档:https://kubernetes.io/ K8s中文官方文…...
ARM--day2(cpsr、spsr、数据搬移指令、移位操作指令、位运算操作指令、算数运算指令、比较指令、跳转指令)
.text .global _gcd _gcd:mov r0,#9mov r1,#15b loop loop:cmp r0,r1beq stopsubhi r0,r1bhi loopsubcc r1,r0bcc loopstop:b stop.end用for循环实现1~100之间和5050 .text .global _gcd _gcd:mov r0,#0x0mov r1,#0x1mov r2,#0x64b loop loop:cmp r1,r2bhi stopadd r0,r0,r1ad…...
idea报错:java: 程序包org.springframework.web.bind.annotation不存在
这个错误通常都是maven仓库的问题,试了网上很多方法,都没有解决,如果大家有遇到这个问题,且试了很多方法之后都没有解决,不妨可以试试我这个方法 先编译一下已经写好的代码,这时候会出现以上报错ÿ…...
Android平台GB28181设备接入端如何实现多视频通道接入?
技术背景 我们在设计Android平台GB28181设备接入模块的时候,有这样的场景诉求,一个设备可能需要多个通道,常见的场景,比如车载终端,一台设备,可能需要接入多个摄像头,那么这台车载终端设备可以…...
Evaluation Warning: The document was created with Spire.Doc for JAVA.
spire.doc-5.4.10.jar 生成PDF有广告语水印【Evaluation Warning: The document was created with Spire.Doc for JAVA.】 <!-- maven库访问不了 https://mvnrepository.com/artifact/e-iceblue/spire.doc e-iceblue库才能访问 https://repo.e-iceblue.cn/repository/maven…...
为什么要使用幂等防重复提交,它的逻辑是什么对比其他的来说有什么优势
好,这个问题非常关键,尤其是在金融、支付、电商、表单提交流水线等场景,理解“为什么用幂等 防重复提交”和“它和其他方案比的优势”是做高可靠系统的核心。一、为什么要做幂等防重复提交?1️⃣ 重复请求是现实世界里的必然在真…...
Phi-4-mini-reasoning保姆级教程:14GB显存跑通128K长上下文推理
Phi-4-mini-reasoning保姆级教程:14GB显存跑通128K长上下文推理 1. 模型介绍 Phi-4-mini-reasoning是微软推出的3.8B参数轻量级开源模型,专为数学推理、逻辑推导和多步解题等强逻辑任务设计。这个模型主打"小参数、强推理、长上下文、低延迟"…...
Three.js面试必备:从光源类型到性能优化的20个高频考点解析
Three.js面试深度攻略:从核心原理到性能优化的20个技术要点 当面试官抛出"Three.js的光照系统如何影响渲染性能"这类问题时,你是否能条理清晰地拆解环境光与平行光的计算差异?面对"如何实现自定义着色器优化建筑可视化项目的渲…...
CN3881-规格书 如韵电子 10A 降压型同步单节锂电池充电管理集成电路
概述: CN3881 是一款可使用太阳能供电的 PWM 降压模式单节锂电池充电管理集成电路,可独立对单 节锂电池充电进行管理,具有封装外形小,外围元器件少和使用简单等优点。 CN3881 采用涓流,恒流和恒压充电模式,非常适合单节…...
将大疆无人机GPS数据接入ROS:一份从PSDK C++示例到sensor_msgs/NavSatFix话题的完整改造指南
大疆无人机GPS数据与ROS深度集成实战指南 1. 系统架构设计与环境准备 在机器人导航系统中,高精度定位数据是核心要素之一。大疆Matrice 350 RTK无人机搭载的GPS/RTK模块能够提供厘米级定位精度,而ROS(Robot Operating System)作为…...
如何解决bilibili-api中BV号与AV号转换的技术难题?
如何解决bilibili-api中BV号与AV号转换的技术难题? 【免费下载链接】bilibili-api 哔哩哔哩常用API调用。支持视频、番剧、用户、频道、音频等功能。原仓库地址:https://github.com/MoyuScript/bilibili-api 项目地址: https://gitcode.com/gh_mirrors…...
LoRaFi库详解:面向SX1272/SX1273的Arduino LoRa通信开发指南
1. 项目概述LoRaFi 是一款面向 Arduino 平台的 LoRa 无线通信库,专为基于 Semtech SX1272/SX1273 射频芯片的硬件平台设计,核心适配对象为 LoRaFi 开发板(含配套扩展板/模块)。该库并非通用 LoRa 协议栈,而是聚焦于物理…...
用ESP32和2.13寸电子价签墨水屏,DIY一个超省电的桌面网络时钟(附完整代码)
用ESP32和2.13寸电子价签墨水屏打造极简网络时钟:从硬件拆解到代码实战 在智能设备泛滥的今天,一块能安静显示时间且不打扰生活的时钟反而成了稀罕物。本文将带你用ESP32开发板和汉朔2.13寸电子价签墨水屏,打造一个年耗电量不足1度电的极简网…...
手把手教你用STM32的ADC读取PT100模块,实现高精度温度采集(附完整代码)
基于STM32的PT100高精度温度采集系统设计与实现 在工业控制和精密测量领域,温度监测的准确性往往直接影响产品质量和生产安全。PT100作为最常用的温度传感器之一,凭借其优异的线性度和稳定性,成为众多工程师的首选。本文将深入探讨如何利用ST…...
EPSON RX8010SJ RTC与Nordic TWI实战:I2C通讯时序详解与避坑指南
EPSON RX8010SJ RTC与Nordic TWI实战:I2C通讯时序详解与避坑指南 在嵌入式系统中,实时时钟(RTC)模块是许多应用的核心组件之一。EPSON RX8010SJ作为一款低功耗、高精度的RTC芯片,广泛应用于物联网设备、可穿戴设备和工…...
