vue3中使用router4 keepalive的问题

目录
  • vue3使用router4 keepalive问题
  • 使用keepalive的坑
    • 需求
    • 解决

vue3使用router4 keepalive问题

项目从vue2升级到vue3,路由也紧跟着升级到了4,然后在使用keep-alive的时候一直不生效,就去查文档

vue2.x与vue3.0的App.vue配置有差异,在App.vue配置信息如下:

vue2.x中,router-view可整个放入keepalive中,如下:

<template>
    <!-- vue2.x配置 -->
   <keep-alive>
    <router-view v-if="$route.meta.keepAlive" />
  </keep-alive>
  <router-view v-if="!$route.meta.keepAlive"/>
</template>
<template>
  <!-- vue3.0配置 -->
  <router-view v-slot="{ Component }">
    <keep-alive>
      <component :is="Component"  v-if="$route.meta.keepAlive"/>
    </keep-alive>
    <component :is="Component"  v-if="!$route.meta.keepAlive"/>
  </router-view> 
</template>

但是假如按照这样配置,会有一个问题,假如A页面时缓存页面,跳转到B页面也是缓存页面的话

就会是报Uncaught (in promise) TypeError: parentComponent.ctx.deactivate is not a function 这个错误

所以 需要再中间中配置key值,来表示组件的唯一性和对应关系,如::key="$route.path"

而且 不要动态修改to.meta.keepAlive的值控制是否缓存。

会存在第一次将to.meta.keepAlive设置为true是还是会发送请求,因为第一次是创建组件,没有缓存,需要缓存后,下一次进入才不会发送请求。因为如果最开始进入的时候to.meta.keepAlive值为false的话,渲染的是没有使用keep-alive的组件。

使用keepalive的坑

vue中使用keepAlive数据不刷新,只缓存第一次进入的页面数据。

需求

首页进入列表页,根据不同id刷新列表页面数据,列表页进入详情页,详情页返回列表页时不刷新。

<keep-alive>
        <router-view v-if="$route.meta.keepAlive"></router-view>
</keep-alive>
        <router-view v-if="!$route.meta.keepAlive">
</router-view>
{
        path: '/detail/:type/:articleId/:expertId/:status/:synMatchId/:matchType',
        name: 'Detail',
        component: () => import( /* webpackChunkName: "detail" */ '../views/Detail'),
        meta: {
            hidden: true,
            title: "详情"
        }
},
{
        path: '/match/detail/:id',
        name: 'MatchDetail',
        component: () => import( /* webpackChunkName: "matchdetail" */ '../views/Match/detail.vue'),
        meta: {
            hidden: true,
            title: "详情",
            keepAlive: true
        }
},

这个路由是列表页的路由,按照这种方式写的话确实会缓存页面,但是每次切换页面的时候会导致数据还是旧的。

解决

首先在路由中配置isrefersh用来监测页面从新获取数据

{
        path: '/detail/:type/:articleId/:expertId/:status/:synMatchId/:matchType',
        name: 'Detail',
        component: () => import( /* webpackChunkName: "detail" */ '../views/Detail'),
        meta: {
            hidden: true,
            title: "详情",
            isrefersh:true
        }
},
{
        path: '/match/detail/:id',
        name: 'MatchDetail',
        component: () => import( /* webpackChunkName: "matchdetail" */ '../views/Match/detail.vue'),
        meta: {
            hidden: true,
            title: "详情",
            keepAlive: true,
            isrefersh:true
        }
},

首页

当离开首页时判断是否去列表页,去的话给isrefersh设置为true

beforeRouteLeave (to, from, next) { 
    if(to.name=="MatchDetail" || to.name=="MatchDetail2")
    {
        to.meta.isrefersh = true;
    }
    next(); 
},

列表页

进入列表页的时候设置keppAlive,然后通过isrefersh判断是否刷新页面

**注:**不用再created 或 mounted生命周期中调用接口了,beforeRouteEnter在每次进入这个页面的时候都会触发

beforeRouteEnter(to, from, next){ 
    to.meta.keepAlive= true; 
    next(vm=>{ 
    //这里把页面初始值重新赋值,以刷新页面 
    if(vm.$route.meta.isrefersh){ 
            vm.programmeData=[]
            vm.$route.meta.isrefersh=false;
            vm.init();// 重新调用数据接口
    } })
},
beforeRouteLeave(to, from, next) {
    from.meta.keepAlive= true
    next();
},

详情页

在详情页中判断如果返回列表页设置keepAlive,并不需要刷新数据。

beforeRouteLeave (to, from, next) { 
    if(to.name=="MatchDetail" || to.name=="MatchDetail2"){
        to.meta.keepAlive = true; 
        to.meta.isrefersh=false; 
      }
    next()
}

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • Vue项目中keepAlive的使用说明(超级实用版)

    目录 keepAlive的使用 一共有三个步骤 keepAlive的注意事项 问题描述 原因 include and exclude max keepAlive的使用 在开发的过程中如果碰到经常浏览需要缓存的页面,而且页面很长需要记录滚动的位置这时就需要用到keepAlive. 一共有三个步骤 1.首先在路由中的mate属性中记录keepAlive,如果需要缓存则置为true. path:'/index', name:''index', component:()=>import('../../i

  • vue中keep-alive多级路由缓存问题

    目录 1.问题描述 2.原因分析 3.解决思路 4.处理过程 1.问题描述 对账中心当便捷导航菜单最后两个是同一模块且是三级及以上菜单时,正常切换两个便捷页签时是可以正常缓存的,但删除最后一个页签时,此时另一个页签页面此时已经不缓存了. 2.原因分析 keep-alive默认支持缓存是两级,对三级及以上层级的页面缓存失效,之前的处理方式为: 监听到路由变化后,将当前的路由的标识及父级标识一起存起来,当多个页面存在时,关闭其中一个页面,也会将本身及父级的标识一起删掉,此时数组中已无父级标识,其他同

  • vue3缓存页面keep-alive及路由统一处理详解

    目录 一.前言 二.使用 1.vue2和vue3的不同 2.页面某些数据不需要缓存 3.动态设置keepAlive属性 4.使用include,exclude配置需要缓存的组件 5.部分页面过来需要缓存,部分页面过来需要刷新 6.缓存只在一级路由生效 总结 一.前言 当使用路由跳转到其他页面的时候,要求缓存当前页面,比如列表页面跳转到详情页面,需要缓存列表内容,并且保存滚动条位置,也有时候需要缓存的页面里面有部分内容不缓存,总之各种情况,下面就列举其中一些例子 vue2和vue3的使用方式是不一

  • Vue设置keepAlive不生效问题及解决

    目录 设置keepAlive不生效 1.在App.vue中的设置 2.在router中的index.js设置 keep-alive缓存组件不生效的坑 坑出现背景 坑的原因 代码如下 设置keepAlive不生效 如演示,Vue页面导航回退后页面重新刷新了,搜索条件及结果都重置了,对于页面需要频繁切换的系统来说,体验不佳,我们希望页面第一次打开时加载,此后回退不再刷新 查阅了Vue官网后,发现vue2.0提供了一个keep-alive组件. 1.在App.vue中的设置 <template> &

  • vue3中使用router4 keepalive的问题

    目录 vue3使用router4 keepalive问题 使用keepalive的坑 需求 解决 vue3使用router4 keepalive问题 项目从vue2升级到vue3,路由也紧跟着升级到了4,然后在使用keep-alive的时候一直不生效,就去查文档 vue2.x与vue3.0的App.vue配置有差异,在App.vue配置信息如下: vue2.x中,router-view可整个放入keepalive中,如下: <template>     <!-- vue2.x配置 --&

  • vue3中keep-alive和vue-router的结合使用方式

    目录 前言 代码 一.为何要使用keep-alive? 二.vue2中使用keep-alive 三.vue3中使用keep-alive 四.keep-alive属性“include,exclude”的使用 前言 keep-alive:Vue内置的一个组件,可以使被包含的组件保留状态,或避免重新渲染. router-view:vue-router内置组件, 如果直接包含在keep-alive里面,所有路径匹配到的组件都会被缓存. 提示:以下是本篇文章正文内容,下面案例可供参考 代码 Hmoe组件:

  • vue2.x中h函数(createElement)与vue3中的h函数详解

    目录 1. vue2.x的 h 函数(createElement) 2. vue3 h函数配置项 2.1 v-model实现(以下开始为官网实现) 2.2 v-on 2.3 事件修饰符 2.4 插槽 2.5 component 和 is 2.6 自定义指令 2.7 内置组件 2.8 渲染函数的返回值 2.9 JSX 总结 1. vue2.x的 h 函数(createElement) 使用方法及介绍:(参考官网提取) h函数第一个是标签名字 或者是组件名字,第二个参数是配置项,第三个参数是 inn

  • vue3中使用ant-design-vue的layout组件实现动态导航栏和面包屑功能

    目录 0 前言 1 准备工作 1.1 安装ant-design-vue 1.2 安装图标组件包 2 选择组件 3 路由文件 4 Vue导航页面 5 最终效果 0 前言 最近在自己搞一个前后端小项目,前端想使用ant-design-vue的layout组件实现动态导航栏和面包屑,但是网上的资料较少,所以我就自己整合实现了一下,在此记录分享. 1 准备工作 基于一个新建的Vue3项目上实现. 1.1 安装ant-design-vue 官方文档:Components Overview - Ant De

  • Vue3 中的数据侦测的实现

    在10月05日凌晨Vue3的源代码正式发布了,来自官方的消息: 目前的版本是 Pre-Alpha , 仓库地址:Vue-next,可以通过Composition API了解更多新版本的信息,目前版本单元测试相关情况vue-next-coverage. 文章大纲: Vue 的核心之一就是响应式系统,通过侦测数据的变化,来驱动更新视图. 实现可响应对象的方式 通过可响应对象,实现对数据的侦测,从而告知外界数据变化.实现可响应对象的方式: getter 和 setter defineProperty

  • 详解Vue3中对VDOM的改进

    前言 vue-next 对virtual dom的patch更新做了一系列的优化,从编译时加入了 block 以减少 vdom 之间的对比次数,另外还有 hoisted 的操作减少了内存的开销.本文写给自己看,做个知识点记录,如有错误,还请不吝赐教. VDOM VDOM的概念简单来说就是用js对象来模拟真实DOM树.由于MV**的架构,真实DOM树应该随着数据(Vue2.x中的data)的改变而发生改变,这些改变可能是以下几个方面: v-if v-for 动态的props(如:class,@cl

  • vue3中轻松实现switch功能组件的全过程

    what 编程语言里面,除了使用 if 语句来做条件判断,还有另外一个常用的就是 switch 了. 而在 vue 中,官方已经帮助我们实现了 v-if 这个指令,但是还没有 switch ,那我们能不能自己实现一个呢? 这篇文章就是来探索这个问题,并且最终实现一个 Switch 组件 以终为始 先来看看我们希望用户是如何使用 Switch 的 用 js 的方式来对比一下: 用户可以通过一个 VSwitch 组件来应用 switch 功能 通过 case 来确定匹配的条件 然后每一个 case

  • 详解vue3中组件的非兼容变更

    函数式组件 functional attribute 在单文件组件 (SFC) <template> 已被移除 { functional: true } 选项在通过函数创建组件已被移除 // 使用 <dynamic-heading> 组件,负责提供适当的标题 (即:h1,h2,h3,等等),在 2.x 中,这可能是作为单个文件组件编写的: // Vue 2 函数式组件示例 export default { functional: true, props: ['level'], re

  • 详解Vue3中Teleport的使用

    在本文中,我们将介绍: Teleport 的目的 Teleport 的例子 一些很有意思的代码交互 Teleport 的目的 首先是什么时候以及使用这个 Teleport 功能. 在开发较大的 Vue 项目时应该以可重用的逻辑去组织代码.但是当处理某些类型的组件(如模式.通知或工具提示)时,模板 HTML 的逻辑可能不会和我们希望渲染元素处于相同的文件中. 实际上在大多数情况下,与 Vue 的 DOM 完全分开处理相比,处理这些元素要容易得多.因为嵌套组件的位置.z-index 和样式等这些东西

  • Vue3中ref与toRef的区别浅析

    1. ref是复制,视图会更新 如果利用ref将某一个对象中的某一个属性值变成响应式数据 我们修改响应式数据是不会影响原始数据的; 同时视图会跟新. ref就是复制 复制是不会影响原始数据的 <template> <div> <div> <div>{{stateObj}}</div> <button @click="func1">按钮</button> </div> </div>

随机推荐