vue3 + vue-router + keep-alive缓存页面
1.vue-router中增加mate.keepAlive和deepth属性
{path: '/',name: 'home',component: HomeView,meta: {// 当前页面要不要缓存keepAlive: false,// 当前页面层级deepth: 1,}},{path: '/list',name: 'list',component: ListView,meta: {// 当前页面要不要缓存keepAlive: true,// 当前页面层级deepth: 2,}},{path: '/info',name: 'info',component: InfoView,meta: {// 当前页面要不要缓存keepAlive: false,// 当前页面层级deepth: 3,}},
2.App.vue页面template中增加keep-alive
<template><router-view v-slot="{ Component, route }"><keep-alive :include="include"><component :is="Component" v-if="route.meta.keepAlive" /></keep-alive><component :is="Component" v-if="!route.meta.keepAlive" /></router-view>
</template>
3.App.vue页面js中增加逻辑
export default {setup() {const router = useRouter();// 用于记录实际缓存页面名称const data = reactive({include: []});router.afterEach((to, from) => {// 把要缓存的页面加入缓存列表// 如果 要 to(进入) 的页面是需要 keepAlive 缓存的,把 name push 进 include数组if (to.meta.keepAlive) {!data.include.includes(to.name) && data.include.push(to.name);}// 解决从首页进入列表页面的时候,读取的是缓存页面,如:// 第一次从首页进入列表页面,读取新数据,缓存起来,然后,返回首页// 第二次再进入列表页面,读取的是第一次进入的缓存,不更新。// 如果 要 form(离开) 的页面是 keepAlive缓存的,// 再根据 deepth 来判断是前进还是后退// 如果是后退,就把当前页面从缓存列中删除,if (from.meta.keepAlive && to.meta.deepth < from.meta.deepth) {var index = data.include.indexOf(from.name);index !== -1 && data.include.splice(index, 1);}})return { ...toRefs(data) }}
}
4.在缓存实际页面增加name属性和路由中name设置的相同
// List.vue
export default {name: 'list', // 对应路由中name:'list'的值components: {},setup(){}
}
5.遇到的问题
1.一开始直接用meta.keepAlive的值判断是否需要缓存,导致从列表进入详情,再从详情返回列表的时候是对的,再从列表返回首页,再从首页进入列表就读取缓存不更新了。
2.使用keep-alive的include属性解决1中的问题。但是明明细逻辑里已经把要缓存的name加入到缓存列表中了,就是不生效。
3.在要缓存的组件中,加入name属性解决2中的问题。
相关文章:
vue3 + vue-router + keep-alive缓存页面
1.vue-router中增加mate.keepAlive和deepth属性 {path: /,name: home,component: HomeView,meta: {// 当前页面要不要缓存keepAlive: false,// 当前页面层级deepth: 1,}},{path: /list,name: list,component: ListView,meta: {// 当前页面要不要缓存keepAlive: true,// 当前页…...
unigui同页面内重定向跳转,企业微信内部应用开发获取用户code例子
procedure TMainForm.UniFormCreate(Sender: TObject); varurl: string;code: string; begin //如果没有code值,将进行重定向if UniApplication.Parameters.Values[code] thenbeginurl :https://open.weixin.qq.com/connect/oauth2/authorize?appid你们的企业ID&…...
垃圾数据啊
const arr [] //定义空数组 for (const key in this.fgkSyData) { //循环 this。sgksudata 数据arr.push( //push添加到 arr { [key]:this.fgkSyData[key] } //{} 在对象中 重新 定义key value 转换成对象) } console.log(arr, arr) …...
GB/T 29498-2013 木门窗检测
木门窗是指以木材、木质复合材料为主要材料制作框和扇的门窗。 GB/T 29498-2013 木门窗检测项目 测试项目 测试标准 外观质量 GB/T 29498 尺寸 GB/T 29498 装配质量 GB/T 29498 含水率 GB/T 17657 附着力 GB/T 4893.4 外门窗耐冷热循环 GB/T 4893.7 耐划痕 GB/…...
rocketMQ5.0顺序消息golang接入
本人理解,顺序消息如果不分消息组,那么会影响并行处理速度,所以尽量消息组分的散一些 首先上要求,官方文档如下: 总结: 1.必须同一个消息组,消息组和消费组不是一个概念,不要混 2.必…...
HuggingFace-利用BERT预训练模型实现中文情感分类(下游任务)
准备数据集 使用编码工具 首先需要加载编码工具,编码工具可以将抽象的文字转成数字,便于神经网络后续的处理,其代码如下: # 定义数据集 from transformers import BertTokenizer, BertModel, AdamW # 加载tokenizer token Ber…...
PSP - 从头搭建 抗原类别 (GPCR) 的 蛋白质结构预测 项目流程
欢迎关注我的CSDN:https://spike.blog.csdn.net/ 本文地址:https://spike.blog.csdn.net/article/details/134595717 GPCRs(G Protein-Coupled Receptors,G蛋白偶联受体),又称为7次跨膜受体,是细…...
城市NOA加速落地,景联文科技高质量数据标注助力感知系统升级
当前,自动驾驶技术的演进正在经历着从基础L2到L3过渡的重要阶段,其中NOA(自动辅助导航驾驶)扮演着至关重要的角色。城市NOA(L2.9)作为城市场景下的NOA,被看作是车企向更高阶自动驾驶迈进的必经之…...
控制反转(IoC)是什么?
文章目录 控制反转(Inversion of Control,IoC)传统的程序设计中:应用程序控制程序流程控制反转设计中:由框架或容器控制程序流程IoC 的作用 举例生活例子软件工程例子 控制反转(Inversion of Control&#…...
Redisson分布式锁源码解析、集群环境存在的问题
一、使用Redisson步骤 Redisson各个锁基本所用Redisson各个锁基本所用Redisson各个锁基本所用 二、源码解析 lock锁 1) 基本思想: lock有两种方法 一种是空参 另一种是带参 * 空参方法:会默认调用看门狗的过期时间30*1000&…...
2016年10月4日 Go生态洞察:HTTP追踪介绍
🌷🍁 博主猫头虎(🐅🐾)带您 Go to New World✨🍁 🦄 博客首页——🐅🐾猫头虎的博客🎐 🐳 《面试题大全专栏》 🦕 文章图文…...
分布式篇---第四篇
系列文章目录 文章目录 系列文章目录前言一、分布式ID生成有几种方案?二、幂等解决方法有哪些?三、常见负载均衡算法有哪些?前言 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站,这篇文章男女通用,看懂了就去分享给…...
从零开始的C++(十九)
红黑树: 一种接近平衡的二叉树,平衡程度低于搜索二叉树。 特点: 1.根节点为黑 2.黑色结点的子结点可以是红色结点或黑色结点。 3.红色结点的子结点只能是黑色结点。 4.每个结点到其所有叶子结点的路径的黑色结点个数相同。 5.指向空的…...
opencv-使用 Haar 分类器进行面部检测
Haar 分类器是一种用于对象检测的方法,最常见的应用之一是面部检测。Haar 分类器基于Haar-like 特征,这些特征可以通过计算图像中的积分图来高效地计算。 在OpenCV中,Haar 分类器被广泛用于面部检测。以下是一个简单的使用OpenCV进行面部检测…...
C++纯虚函数和抽象类 制作饮品案例(涉及知识点:继承,多态,实例化继承抽象类的子类,多文件实现项目)
一.纯虚函数的由来 在多态中,通常父类中虚函数的实现是毫无意义的,主要都是调用子类重写的内容。例如: #include<iostream>using namespace std;class AbstractCalculator { public:int m_Num1;int m_Num2;virtual int getResult(){r…...
什么是网关和链路追踪,以及怎么使用?
在云计算中,网关和链路追踪也是非常重要的。云服务提供商通常会提供网关和链路追踪等相关服务来帮助用户管理和优化云计算网络。 云计算中的网关通常包括以下几种: 虚拟网络网关:用于将云中不同虚拟网络之间相互连接,实现云内不同…...
git 文件被莫名其妙的或略且无论如何都查不到哪个.gitignore文件忽略的
先说解决办法:git check-ignore -v [文件路径] 这个命令会返回一个忽略规则,以及该规则在哪个文件中定义的,该规则使得指定的文件被忽略。 1.遇到的问题 同项目组,其他同学都可以正常的提交.meta文件,我的提交就出现以…...
nova组件简介
目录 组件关系图 controller节点 openstack-nova-api.service: openstack-nova-conductor.service: openstack-nova-consoleauth.service: openstack-nova-novncproxy.service: openstack-nova-scheduler.service: openstack-nova-conductor.service详解 作用和功能&…...
【Vue】响应式与数据劫持
Vue.js 是一个渐进式的 JavaScript 框架,其中最重要的一个特性就是响应式(Reactivity)。Vue 借助数据劫持(Data Observation)技术实现了对数据的响应式更新,当数据发生变化时,它会自动重新渲染视…...
Modbus RTU转Profinet网关连接PLC与变频器通讯在机床上应用案例
背景:以前在机床加工车间里,工人们忙碌地操作着各种机床设备。为了使整个生产过程更加高效、流畅,进行智能化改造。 方案:在机床上,PLC通过Modbus RTU转Profinet网关连接变频器进行通讯:PLC作为整个生产线…...
手机号码定位查询终极指南:3步实现精准地理位置识别
手机号码定位查询终极指南:3步实现精准地理位置识别 【免费下载链接】location-to-phone-number This a project to search a location of a specified phone number, and locate the map to the phone number location. 项目地址: https://gitcode.com/gh_mirror…...
终极指南:如何用CXPatcher一键提升Mac上CrossOver游戏性能
终极指南:如何用CXPatcher一键提升Mac上CrossOver游戏性能 【免费下载链接】CXPatcher A patcher to upgrade Crossover dependencies and improve compatibility 项目地址: https://gitcode.com/gh_mirrors/cx/CXPatcher 还在为Mac上运行Windows游戏卡顿、闪…...
AC-GAN原理与实践:实现类别可控的图像生成
1. 项目概述:理解AC-GAN的核心价值AC-GAN(Auxiliary Classifier GAN)是生成对抗网络家族中一个极具实用价值的变体。我第一次接触这个架构是在解决图像生成任务时,发现普通GAN生成的图像虽然质量不错,但无法精确控制生…...
【2026年阿里巴巴集团暑期实习- 4月25日-AI研发岗-第三题- 区间第K小】(题目+思路+JavaC++Python解析+在线测试)
题目内容 给定一个长度为$ n 的整数序列的整数序列的整数序列 a_1, a_2, \dots, a_n$。定义 f(l,r)=∑i=lr(∑t=liat)f(l, r) = \sum_{i=l}^{r} \left( \sum_{t=l}^{i} a_t \right)f(l...
alt+tab和win+tab什么区别
这两个快捷键虽然都是用来切换窗口的,但它们的设计理念和适用场景完全不同。 简单来说:Alt + Tab 是为了“快”,而 Win + Tab 是为了“全”。 以下是详细的区别对比: 核心区别对比表 表格 特性 Alt + Tab Win + Tab 主要功能 快速切换 任务管理 操作方式 需按住 Alt 不…...
Java方法级性能监控利器MyPerf4J:低侵入、高精度的性能剖析实战
1. 项目概述与核心价值最近在排查一个线上服务的性能瓶颈,发现传统的日志埋点和监控系统在定位高并发下的方法级耗时毛刺时,总是慢半拍,信息也不够直观。直到团队里的架构师扔给我一个GitHub链接,说“试试这个,轻量级&…...
机载视频 SEI 解析与抽帧
机载视频 SEI 解析与抽帧 一、模块要解决什么问题 机载吊舱录制的视频中,常通过码流侧的补充增强信息附带 POS、姿态、时间、焦距 等。测绘内业需要两类产物: 仅解析 SEI:得到与解码帧对齐的记录列表,供质检、对时、与定拍数据融合…...
自动化任务系列之五:PDF批量转换+自动清理——文件格式规范化工作流
凌晨三点,项目群里弹出一条消息:“这周要给客户交付全套图纸,但是那个AI文件转PDF转了两天还没转完,你们谁去盯着一下?” 我盯着屏幕,整个人都傻了。48小时的等待,换回来的是服务器上一堆半成品…...
ServiceNow AgentLab:企业级AI智能体开发与工作流自动化实战指南
1. 项目概述:当AI智能体遇上企业级工作流如果你在IT服务管理、企业流程自动化或者AI应用开发领域待过一段时间,那么ServiceNow这个名字你一定不陌生。它几乎是大型企业IT服务台、IT运维和业务流程管理的代名词。而“AgentLab”这个项目,简单来…...
Keras实现Mask R-CNN目标检测与实例分割实战
1. 基于Keras的Mask R-CNN目标检测实战指南在计算机视觉领域,目标检测一直是最具挑战性的任务之一。它不仅需要识别图像中的物体是什么(分类),还需要精确确定它们的位置(定位)。作为一名长期从事计算机视觉…...
