vue 前进刷新后退不刷新

2024-08-29 19:12

本文主要是介绍vue 前进刷新后退不刷新,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本篇主要讲述vue如何通过路由实现“前进刷新后退不刷新”功能。

1. 在App.vue中配置keep-alive

// <router-view></router-view> 外添加<template><div id="app"><!-- 前进后退都刷新 --><!-- <router-view></router-view> --><keep-alive><!-- 这里是会被缓存的视图组件 --><router-view v-if="$route.meta.keepAlive"></router-view></keep-alive><!-- 这里是不被缓存的视图组件 --><router-view v-if="!$route.meta.keepAlive"></router-view></div>
</template>

2. 配置router路由,即meta对象中添加keepAlive属性

{path: '/add/addInfo',name: "addInfo",component: resolve => require(["../page/add/addInfo.vue"], resolve),meta: {keepAlive: false, //此组件不需要被缓存}
},
{path: '/add/jtinfo',name: "jtinfo",component: resolve => require(["../page/add/jtinfo.vue"], resolve),meta: {keepAlive: true, //此组件需要被缓存sBack: false,}
},

3.在需要缓存的页面配置

  data(){return {isFirstEnter: false, // 是否第一次进入,默认falsedatas: [], //页面的数据}},created() {// 只有第一次进入或者刷新页面后才会执行此钩子函数// 使用keep-alive后(2+次)进入不会再执行此钩子函数this.isFirstEnter=true;},activated() {if(!this.$route.meta.isBack || this.isFirstEnter){// 如果isBack是false,表明需要获取新数据,否则就不再请求,直接使用缓存的数据// 如果isFirstEnter是true,表明是第一次进入此页面或用户刷新了页面,需获取新数据this.datas=''// 把数据清空,可以稍微避免让用户看到之前缓存的数据// 执行了 mounted 中的事件/*this.loaGongkeInfoSearck()this.TabSwitch(0);this.heightM = document.body.scrollHeight;*/}// 恢复成默认的false,避免isBack一直是true,导致下次无法获取数据this.$route.meta.isBack=false// 恢复成默认的false,避免isBack一直是true,导致每次都获取新数据this.isFirstEnter=false;},beforeRouteEnter(to, from, next) {// 路由导航钩子,此时还不能获取组件实例 `this`,所以无法在data中定义变量(利用vm除外)// 参考 https://router.vuejs.org/zh-cn/advanced/navigation-guards.html// 所以,利用路由元信息中的meta字段设置变量,方便在各个位置获取。这就是为什么在meta中定义isBack// 参考 https://router.vuejs.org/zh-cn/advanced/meta.htmlif(from.name=='addInfo'){ //from.name即是路由里面的name属性值,即路径//判断是从哪个路由过来的to.meta.isBack=true; // 该路由过来当前页面 不需要刷新 获取新数据,直接用之前缓存的数据即可}if(from.name=='jtinfo'){to.meta.isBack=false;// 该路由过来当前页面 需要刷新 获取新数据}next();},

看看代码注释吧,应该不难理解。
这算是一种比较古老的实现方式了。
最后:大吉大利,祝你没BUG。

这篇关于vue 前进刷新后退不刷新的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1118676

相关文章

前端如何通过nginx访问本地端口

《前端如何通过nginx访问本地端口》:本文主要介绍前端如何通过nginx访问本地端口的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、nginx安装1、下载(1)下载地址(2)系统选择(3)版本选择2、安装部署(1)解压(2)配置文件修改(3)启动(4)

HTML中meta标签的常见使用案例(示例详解)

《HTML中meta标签的常见使用案例(示例详解)》HTMLmeta标签用于提供文档元数据,涵盖字符编码、SEO优化、社交媒体集成、移动设备适配、浏览器控制及安全隐私设置,优化页面显示与搜索引擎索引... 目录html中meta标签的常见使用案例一、基础功能二、搜索引擎优化(seo)三、社交媒体集成四、移动

HTML input 标签示例详解

《HTMLinput标签示例详解》input标签主要用于接收用户的输入,随type属性值的不同,变换其具体功能,本文通过实例图文并茂的形式给大家介绍HTMLinput标签,感兴趣的朋友一... 目录通用属性输入框单行文本输入框 text密码输入框 password数字输入框 number电子邮件输入编程框

HTML img标签和超链接标签详细介绍

《HTMLimg标签和超链接标签详细介绍》:本文主要介绍了HTML中img标签的使用,包括src属性(指定图片路径)、相对/绝对路径区别、alt替代文本、title提示、宽高控制及边框设置等,详细内容请阅读本文,希望能对你有所帮助... 目录img 标签src 属性alt 属性title 属性width/h

CSS3打造的现代交互式登录界面详细实现过程

《CSS3打造的现代交互式登录界面详细实现过程》本文介绍CSS3和jQuery在登录界面设计中的应用,涵盖动画、选择器、自定义字体及盒模型技术,提升界面美观与交互性,同时优化性能和可访问性,感兴趣的朋... 目录1. css3用户登录界面设计概述1.1 用户界面设计的重要性1.2 CSS3的新特性与优势1.

HTML5 中的<button>标签用法和特征

《HTML5中的<button>标签用法和特征》在HTML5中,button标签用于定义一个可点击的按钮,它是创建交互式网页的重要元素之一,本文将深入解析HTML5中的button标签,详细介绍其属... 目录引言<button> 标签的基本用法<button> 标签的属性typevaluedisabled

HTML5实现的移动端购物车自动结算功能示例代码

《HTML5实现的移动端购物车自动结算功能示例代码》本文介绍HTML5实现移动端购物车自动结算,通过WebStorage、事件监听、DOM操作等技术,确保实时更新与数据同步,优化性能及无障碍性,提升用... 目录1. 移动端购物车自动结算概述2. 数据存储与状态保存机制2.1 浏览器端的数据存储方式2.1.

基于 HTML5 Canvas 实现图片旋转与下载功能(完整代码展示)

《基于HTML5Canvas实现图片旋转与下载功能(完整代码展示)》本文将深入剖析一段基于HTML5Canvas的代码,该代码实现了图片的旋转(90度和180度)以及旋转后图片的下载... 目录一、引言二、html 结构分析三、css 样式分析四、JavaScript 功能实现一、引言在 Web 开发中,

CSS place-items: center解析与用法详解

《CSSplace-items:center解析与用法详解》place-items:center;是一个强大的CSS简写属性,用于同时控制网格(Grid)和弹性盒(Flexbox)... place-items: center; 是一个强大的 css 简写属性,用于同时控制 网格(Grid) 和 弹性盒(F

CSS实现元素撑满剩余空间的五种方法

《CSS实现元素撑满剩余空间的五种方法》在日常开发中,我们经常需要让某个元素占据容器的剩余空间,本文将介绍5种不同的方法来实现这个需求,并分析各种方法的优缺点,感兴趣的朋友一起看看吧... css实现元素撑满剩余空间的5种方法 在日常开发中,我们经常需要让某个元素占据容器的剩余空间。这是一个常见的布局需求