当前位置: 首页 > news >正文

Vue3 对跳转 同一路由传入不同参数的页面分别进行缓存

1:使用场景

     从列表页跳转至不同的详情页面,对这些详情页面分别进行缓存

2:核心代码

2.1: 配置路由文件

在路由文件里对需要进行缓存的路由对象添加meta 属性

 // 需要缓存的详情页面路由
  {
    name: detail,
    path: '/myRouter/detail', // 路径
    component: () => import('../views/abc/detail.vue'),
    meta: {
      keepAlive: true, // 是否被缓存
    },
  },

2.2: app页面增加缓存逻辑

<template>
  <el-config-provider :locale="locale">
    <!-- 有条件的进行缓存 -->
    <transition mode="out-in" name="fade">

      <router-view v-slot="{ Component }">
        <keep-alive :include="includeList">
          <component :is="wrap(route?.name , route.query, Component)" :key="route.fullPath" />
        </keep-alive>
      </router-view>
    </transition>
  </el-config-provider>
</template>

wrap 方法

    const wrapperMap = new Map();const wrap = (name:any, query:any, component:any) => {let wrapper;let wrapperName;if(query.catchName){wrapperName = name + '-' + query.catchName;}else {wrapperName  = name;}if (wrapperMap.has(wrapperName)) {wrapper = wrapperMap.get(wrapperName);} else {wrapper = {name: wrapperName,render() {return h('div', { className: 'vaf-page-wrapper' }, component);},};wrapperMap.set(wrapperName, wrapper);}return h(wrapper);};

watch 监听对于route.query 是否存在catchName 参数的路由分别进行缓存

// 监听路由,判断页面是否需要缓存watch(() => route,(newVal: any, oldVal) => {if (newVal.query?.catchName) {if (newVal.meta.keepAlive && !state.includeList.includes(newVal.name + '-' + newVal.query?.catchName)) {state.includeList.push(newVal.name + '-' + newVal.query?.catchName);}} else if (newVal.meta.keepAlive && !state.includeList.includes(newVal.name)) {state.includeList.push(newVal.name);}},{deep: true, // 开启深度监听},);

2.3: 在列表页面的查看点击方法中配置路由添加query 传参 catchName

注:上面为核心代码逻辑,需要根据实际情况进行调整。

http://www.lryc.cn/news/395055.html

相关文章:

  • LinearLayout的测量流程
  • 数据无忧:Ubuntu 系统迁移备份全指南
  • 中国IDC圈探访北京•光子1号金融算力中心
  • [Unity入门01] Unity基本操作
  • vivado DELAY_VALUE_XPHY、DIFF_TERM
  • C++语言相关的常见面试题目(三)
  • 代码随想录-Day53
  • Android 如何通过代码实时设置EditTextView光标
  • 202488读书笔记|《365日创意文案》——无聊的 到底是这世间, 还是自己?懂得忘却的人才能前进
  • iperf3: error - unable to connect to server: No route to host
  • 正则表达式中的贪心匹配
  • 线程相关概念及操作
  • 2024最新版若依-RuoYi-Vue3-PostgreSQL前后端分离项目部署手册教程
  • PHP源码:新闻门户系统(附管理后台+前台)
  • 15kg级弹簧刀高速巡飞无人机技术详解
  • 中国东方资产管理25届秋招北森测评笔试如何高分通过?真题考点分析看完这篇就够了
  • 简写单词BC149
  • Chapter11让画面动起来——Shader入门精要学习笔记
  • c++之命名空间详解(namespace)
  • 【大模型】在大语言模型的璀璨星河中寻找道德的北极星
  • 嵌入式Linux之Uboot简介和移植
  • 算法整理——【贪心算法练习(1)】
  • 人脸识别课堂签到系统【PyQt5实现】
  • Linux dig命令常见用法
  • 数学建模论文写作文档word
  • 嵌入式C语言面试相关知识——CPU、进程和线程相关(相关问题很多,会经常过来更新)
  • Linux学习看这一篇就够了,超超超牛的Linux基础入门
  • el-scrollbar组件使用踩坑记录
  • Linux计算机结构
  • 应用进程、SurfaceFlinger进程、HWC进程 之间的关系