vue2使用keep-alive缓存多层列表页的方法


Posted in Javascript onSeptember 21, 2018

vue关于列表页和详情页的展现比较让人头疼,在列表页面点击进详情页返回以后,列表页会重新刷新。假如在第五页找到的数据,点击修改后返回又跳回第一页了,这个时候就需要用到keep-alive缓存页面数据,但keep-alive缓存的页面一直不会发生改变,特别是列表页层级很多的情况下,更加复杂。

譬如我后台的一个管理页面,因为数据关联很复杂,所以做了三层列表页嵌套,上一层点击管理就可以进行下一层的数据展现,每一层列表页都包含了3到4个需要循环展现的数据。在加入keep-alive之前我使用路由和自定义组件的方式组织页面的。

路由到详情页,然后详情页加载列表页组件展现,然后在组件模块通过props:[‘id']获取数据

import Vmothod from '../page/ApiMethodTable.vue';
import VsystemParam from '../page/ApiSystemParamTable.vue';
import VsystemError from '../page/ApiSystemErrorTable.vue';
<template>
 <div>
  <Vmothod :id="id"></Vmothod>
  <VsystemParam :id="id"></VsystemParam>
  <VsystemError :id="id"></VsystemError>
 </div>
</template>

但是如此以来,在返回上一层或者修改数据回跳后,因为没有页面缓存,所以页数会变成第一页,使用上很不方便。

在网上找了相关解决方案后,我试着在路由上加入了keep-alive参数。

meta: { keepAlive: true }
<keep-alive>
  <router-view v-if="$route.meta.keepAlive"></router-view>
 </keep-alive>
 <router-view v-if="!$route.meta.keepAlive"></router-view>

这样解决了页面不缓存的问题,但跳转之后所有页面都是一模一样的数据,这就很不对了。后台发觉还要在页面初始化时加入钩子函数拉取数据

activated(){
  this.getData();
 }

但是发觉还是不行,上一页通过props:[‘id']传递到组件参数也会被缓存,如此以来props不能用了,只有通过在路由来传递参数。

在路由的时候带上id参数

path:'/method/:id'

然后在组件页面获取参数

self.$route.params.id

如此终于顺畅的缓存了详情页的当前页面参数。

以上这篇vue2使用keep-alive缓存多层列表页的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
FormValid0.5版本发布,带ajax自定义验证例子
Aug 17 Javascript
js 实现无缝滚动 兼容IE和FF
Jul 15 Javascript
web性能优化之javascript性能调优
Dec 28 Javascript
javascript判断移动端访问设备并解析对应CSS的方法
Feb 05 Javascript
使用 JavaScript 进行函数式编程 (一) 翻译
Oct 02 Javascript
jquery+json实现分页效果
Mar 07 Javascript
使用Node.js给图片加水印的方法
Nov 15 Javascript
jQuery中table数据的值拷贝和拆分
Mar 19 Javascript
Javascript实现异步编程的过程
Jun 18 Javascript
微信小程序动态增加按钮组件
Sep 14 Javascript
解决Vue动态加载本地图片问题
Oct 09 Javascript
AJAX引擎原理以及XmlHttpRequest对象的axios、fetch区别详解
Apr 09 Javascript
使用ng-packagr打包Angular的方法示例
Sep 21 #Javascript
基于vue中keep-alive缓存问题的解决方法
Sep 21 #Javascript
vue中前进刷新、后退缓存用户浏览数据和浏览位置的实例讲解
Sep 21 #Javascript
vue单页面应用打开新窗口显示跳转页面的实例
Sep 21 #Javascript
详解Vue改变数组中对象的属性不重新渲染View的解决方案
Sep 21 #Javascript
默认浏览器设置及vue自动打开页面的方法
Sep 21 #Javascript
详解Vue中数组和对象更改后视图不刷新的问题
Sep 21 #Javascript
You might like
php 常用类整理
2009/12/23 PHP
PHPThumb PHP 图片缩略图库
2012/03/11 PHP
用PHP实现 上一篇、下一篇的代码
2012/09/29 PHP
关于crontab的使用详解
2013/06/24 PHP
微信公众平台开发之配置与请求
2015/08/26 PHP
PHP将数据导出Excel表中的实例(投机型)
2017/07/31 PHP
Ctrl+Enter提交内容信息
2006/06/26 Javascript
jQuery UI的Dialog无法提交问题的解决方法
2011/01/11 Javascript
apycom出品的jQuery精美菜单破解方法
2011/02/18 Javascript
js确认删除对话框适用于a标签及submit
2014/07/10 Javascript
浅谈Javascript中深复制
2014/12/01 Javascript
JS实现黑色大气的二级导航菜单效果
2015/09/18 Javascript
用JavaScript实现让浏览器停止载入页面的方法
2017/01/19 Javascript
详谈表单格式化插件jquery.serializeJSON
2017/06/23 jQuery
Node.js引入UIBootstrap的方法示例
2018/05/11 Javascript
js取小数点后两位四种方法
2019/01/18 Javascript
微信小程序实现的一键拨号功能示例
2019/04/24 Javascript
Vue 3.0 前瞻Vue Function API新特性体验
2019/08/12 Javascript
[07:08]2014DOTA2西雅图国际邀请赛 小组赛7月11日TOPPLAY
2014/07/11 DOTA
深入理解Python3 内置函数大全
2017/11/23 Python
利用信号如何监控Django模型对象字段值的变化详解
2017/11/27 Python
给你一面国旗 教你用python画中国国旗
2019/09/24 Python
flask框架自定义过滤器示例【markdown文件读取和展示功能】
2019/11/08 Python
PyTorch笔记之scatter()函数的使用
2020/02/12 Python
python爬虫利用selenium实现自动翻页爬取某鱼数据的思路详解
2020/12/22 Python
英国最专业的健身器材供应商之一:Best Gym Equipment
2017/12/22 全球购物
Yahoo-PHP面试题2
2014/12/06 面试题
跟单文员岗位职责
2014/01/03 职场文书
合伙协议书
2014/04/23 职场文书
个人债务授权委托书范本
2014/10/05 职场文书
入股合作协议书
2014/10/12 职场文书
2015年医药代表工作总结
2015/04/25 职场文书
幼儿园保教工作总结2015
2015/10/15 职场文书
《分数乘法》教学反思
2016/02/24 职场文书
创业计划书之小型广告公司
2019/10/22 职场文书
Android使用EventBus发送消息,Fragment中接收消息的方法会执行多次
2022/04/24 Java/Android