vue项目中keep-alive的使用,从详情页返回列表时保存浏览位置

背景描述:

最近在做移动端前端项目中,需要实现以下场景:

1.在页面查询列表,进入详情页时,返回需要页面返回到上次浏览的位置

2.由于查询列表获取的数据可能会短时间改变,如果前端长时间缓存数据,并不符合业务要求。

3.我在进入详情页时可以修改列表的数据,返回时滚动到,用户看到的应该是最新的数据

4.每个列表页面需要用到滑动加载更多数据。

项目中vue的使用:

1.用到keep-alive来缓存页面

2.当详情页中改变列表数据时,配合keep-alive,需要在vue钩子函数activated中,对数据进行更改

3.在从其他页面进入时,页面要重新加载数据。页面从列表进入其他页面(非详情页)时,销毁当前的vue实例。此时需用到组件内的路由守卫,beforeRouteEnter和beforeRouteLeave

4.列表页滑动加载

具体实现:

针对以上前三点,页面的缓存,我们需要用到vue的内置组件keep-alive,来缓存列表页面,同时配合路由选项来更改页面的数据。

在设置keep-alive缓存的组件中,首次进入组件,会一次调用组件的钩子函数:created --> mounted -->activated 再次进入时,只触发activated钩子函数

1.在路由出口渲染组件时配置:

      <keep-alive><router-view v-if="$route.meta.keepAlive" class="router-view"></router-view></keep-alive><router-view v-if="!$route.meta.keepAlive" class="router-view" ></router-view>

2.在路由选项中,配置meta属性,keepAlive为true即为需要缓存的组件,同时设置isBack属性,用来标示页面是否是从详情页面返回的。

{name: '首页',path: 'index',component: Index,meta: {keepAlive: true, isBack: false}},

3.在组件实例中,通过beforeRouteEnter(to, from, next)路由守卫,来判断路由是从哪里跳转的,如果是从详情页跳转的,则将当前路由对象的meta.isBack 设置为true,否则设为false

      beforeRouteEnter(to, from, next) {if (from.path == "/detail") {to.meta.isBack = true;} else {to.meta.isBack = false;}next();},

为了在其他页面进入时,更新页面中的列表数据,我们将在activated钩子函数中挂载页面初次进入时的请求数据:

      activated() {if (!this.$route.meta.isBack) {this.list = [];this.pageNum = 1;this.getList();}this.$route.meta.isBack = false;},

4.在进入详情页,需要对该条数据进行修改时,修改成功后返回,应该更新列表。

由于我们要在返回时滚动到浏览位置,因此不能去后台重新请求数据(否则无法回到之前浏览的位置),而是采用前端保存修改的数据,并在返回的activated钩子中对当前列表数据修改。

需要注意的事项:

由于vue自身限制,不能检测到数组直接修改长度和利用索引设值 因此,需要使用vm.$set(vm.array,index,newValue)或者vm.array.splice(index,1,newValue)

然后根据页面离开时保存的滚动位置,将页面滚动到浏览位置。在router-view入口处,watch,$route对象,将keep-alive为true的页面,滚动到上次浏览位置。

5.在页面列表中,我们需要用到分页加载数据,即滑动加载

在keep-alive组件中,页面离开时,并不会销毁当前的vue实例,而是保存在内存中。因此就会造成问题:页面跳转时,触发了滑动事件,加载所有保存在内存中的滑动事件,改变了vue实例的数据。

因此,我们需要在组件的路由守卫中,在页面离开时beforeRouteLeave中把滑动事件禁用,然后再在页面进入的时候,在activated钩子中恢复滑动事件的。

注意: 使用keep-alive不能销毁实例,vm.$destroy(); 否则再进入页面,即使keep-alive为true也不会保存组件。如果keep-alive的页面较多,可以使用,在路由守卫中修改vuex的变量动态改变keep-alive的页面变量。

简单写了个demo,用的移动端ui框架是vux,其中用到的view-box组件,有自己的scroll方法(documment.documentElement.scroll为0)

https://github.com/Cxy56/vue-keepalive-demo

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/367006.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Apache log4j是领先的日志记录框架

根据 从零周转开始的调查中&#xff0c; Apache log4j是领先的Java日志记录框架。 这实际上是一个非常有趣的调查。 它显示SLF4J最常用作伐木外墙&#xff0c;占61&#xff05;。 但是&#xff0c;它似乎最常与Apache Log4j一起使用&#xff0c;52&#xff05;的调查参与者都…

Centos6.8通过yum安装mysql5.7

Centos6.8通过yum安装mysql5.7 2017年07月13日 14:19:10 阅读数&#xff1a;1067 1.安装mysql的yum源 a.下载配置mysql的yum源的rpm包 根据上面3张图片中的操作下载下来的rpm文件可以通过如下命令获取&#xff1a; wget https://dev.mysql.com/get/mysql57-community-release-e…

codeforces Labyrinth

codeforces Labyrinth Time Limit: 2 Sec   Memory Limit: 512 MB Description You are playing some computer game. One of its levels puts you in a maze consisting of n lines, each of which contains m cells. Each cell either is free or is occupied by an obstac…

在vscode使用editorconfig的正确姿势

editorconfig是什么鬼&#xff1f; editorconfig是用来帮助开发者定义和维护代码风格&#xff08;行尾结束符、缩进风格等&#xff09;的东东。 editorconfig支持哪些规则&#xff1f; 请自行参考 https://editorconfig.org/ 如何在vscode中使用editorconfig&#xff1f; 在…

使用Java的Apache Camel入门

Apache Camel是一个非常有用的库&#xff0c;可以帮助您处理来自许多不同来源的事件或消息。 您可以通过许多不同的协议&#xff08;例如在VM&#xff0c;HTTP&#xff0c;FTP&#xff0c;JMS甚至DIRECTORY / FILE之间&#xff09;移动这些消息&#xff0c;但仍使处理代码不受传…

Mvc+Hui+SqlSugar+Autofac+NLog+T4 架构设计(一)

一、前言 作为小菜鸟第一次写博客的我还有点小激动&#xff0c;最近开始打算着手写一个属于自己架构。算下来差不多最近花一周多的下班时间了来写这个框架&#xff0c;本来想整体架构开发完成测试完成后才写博客&#xff0c;怕自己没时间或失去动力&#xff0c;就先把自己架构设…

闲话杂谈—至曾经的自己

【这篇闲话杂谈写的背景时间是&#xff1a;2018年9月30号】 今天估计是自己突然灵光一闪&#xff0c;又或许是想到昨天团建时曾经带自己的师傅&#xff08;刘工&#xff09;的一番话。让我觉得大家都在变化&#xff0c;都慢慢的不再是曾经咱们一块儿奋斗、一块儿无话不谈&#…

房价在手,天下我有 --反手就撸一个爬虫(终)

接上篇&#xff0c;科科&#xff0c;好&#xff0c;我们继续 我们在这里先把json数据入库吧&#xff5e; 首先&#xff0c;database/scheme里定义好数据类型。 const mongoose require(mongoose)const detailHouseSchema new mongoose.Schema({ //定义数据模式link:String…

1.1 计算机网络的形成和发展

1.早期计算机网络&#xff1a;20世纪60年代前 计算机和通信技术结合的先驱&#xff1a;SAGE半自动化地面防空系统 &#xff0c;该系统由麻省理工学院林肯实验室设计。 计算机通信在民用领域的代表&#xff1a;飞机订票系统SABRE-I &#xff0c;美国航空公司与IBM公司联合开发。…

Spring MVC:带有CNVR卷的REST应用程序。 1个

不久前&#xff0c;我阅读了Paul Chapman撰写的有关内容协商视图解析器 &#xff08;CNVR&#xff09;的文章。 Spring Framework Blog上的那篇文章启发了我研究这个框架的领域。 因此&#xff0c;我开发了一个基于Spring MVC和CNVR的 REST示例应用程序。 该应用程序演示了REST…

《精通Spring 4.x 企业应用开发实战》学习笔记

第四章 IoC容器 4.1 IoC概述 IoC&#xff08;Inverse of Control 控制反转&#xff09;&#xff0c;控制是指接口实现类的选择控制权&#xff0c;反转是指这种选择控制权从调用类转移到外部第三方类或容器的手中。 也就是由Spring容器借由Bean配置来进行控制。 DI&#xff08;D…

微前端——无界wujie

B站课程视频 课程视频 课程课件笔记&#xff1a; 1.微前端 2.无界 现有的微前端框架&#xff1a;iframe、qiankun、Micro-app&#xff08;京东&#xff09;、EMP&#xff08;百度&#xff09;、无届 前置 初始化 新建一个文件夹 1.通过npm i typescript -g安装ts 2.然后可…

java executor spring_Spring+TaskExecutor实例

一 TaskExecutor接口Spring的TaskExecutor接口等同于Java.util.concurrent.Executor接口。 实际上&#xff0c;它存在的主要原因是为了在使用线程池的时候&#xff0c;将对Java 5的依赖抽象出来。 这个接口只有一个方法execute(Runnable task)&#xff0c;它根据线程池的语义和…

小程序居然可以用WXS模拟实现过滤器!

小程序目前官方还没有出过滤器&#xff0c;特别不方便&#xff0c;但是可以用wxs来模拟过滤器&#xff0c;话不多说&#xff0c;直接上代码。当然&#xff0c;不熟悉wxs的可以先看一下 官方文档 1.新建一个filter.wxs的文件我个人建议是一个过滤器写一个wxs&#xff0c;避免引用…

ADF:使用HTTP POST方法进行URL任务流调用

众所周知&#xff0c;可以通过某些URL直接从浏览器或某些外部应用程序调用有限任务流。 如果任务流的属性“ URL invoke”设置为“ url-invoke-allowed”&#xff0c;则启用此功能&#xff0c;该功能通常在集成项目中使用。 通常&#xff0c;客户端&#xff08;或调用者&#x…

(十二)Bind读取配置到C#实例

继续上一节的&#xff0c;接下来用Options或者Bind把json文件里的配置转成C#的实体&#xff0c;相互之间映射起来。首先新建一个asp.net core mvc项目OptionsBindSampleStartup.cs&#xff0c;这里用依赖注入把Configuration加进来 1 public IConfiguration Configurat…

转-测试用例-常用控件

1. 文本框 是否是必填项 是 为空时提交&#xff0c;给出提示 输入空格时提交&#xff0c;给出提示 否 为空时提交&#xff0c;可提交成功 不为空时提交&#xff0c;提交后内容与输入的一致&#xff0c;存储到数据库中正确 是否支持TAB键在文本框中输入回车键&#xff0c;是…

java 项目做多级缓存_【开源项目系列】如何基于 Spring Cache 实现多级缓存(同时整合本地缓存 Ehcache 和分布式缓存 Redis)...

一、缓存当系统的并发量上来了&#xff0c;如果我们频繁地去访问数据库&#xff0c;那么会使数据库的压力不断增大&#xff0c;在高峰时甚至可以出现数据库崩溃的现象。所以一般我们会使用缓存来解决这个数据库并发访问问题&#xff0c;用户访问进来&#xff0c;会先从缓存里查…

[译] SpaceAce 了解一下,一个新的前端状态管理库

原文地址&#xff1a;Introducing SpaceAce, a new kind of front-end state library原文作者&#xff1a;Jon Abrams译文出自&#xff1a;掘金翻译计划本文永久链接&#xff1a;https://github.com/xitu/gold-miner/blob/master/TODO1/introducing-spaceace-a-new-kind-of-fro…

Spring MVC:带有CNVR卷的REST应用程序。 3

这是带有CNVR的Spring MVC REST教程的最后一部分。 在这里&#xff0c;我将演示所有这些东西如何工作&#xff0c;这是我在前两部分中开发的。 对于每种类型的CRUD操作&#xff0c;这将分为四个部分&#xff1a;CREATE&#xff0c;READ&#xff0c;UPDATE&#xff0c;DELETE。 …