Vue 实现前进刷新,后退不刷新的效果
Vue 实现 效果 刷新 后退 前进
2023-09-27 14:28:56 时间
更多文章
需求一:
在一个列表页中,第一次进入的时候,请求获取数据。
点击某个列表项,跳到详情页,再从详情页后退回到列表页时,不刷新。
也就是说从其他页面进到列表页,需要刷新获取数据,从详情页返回到列表页时不要刷新。
解决方案
在 App.vue
设置:
<keep-alive include="list">
<router-view/>
</keep-alive>
假设列表页为 list.vue
,详情页为 detail.vue
,这两个都是子组件。
我们在 keep-alive
添加列表页的名字,缓存列表页。
然后在列表页的 created
函数里添加 ajax请求,这样只有第一次进入到列表页的时候才会请求数据,当从列表页跳到详情页,再从详情页回来的时候,列表页就不会刷新。
这样就可以解决问题了。
需求二:
在需求一的基础上,再加一个要求:可以在详情页中删除对应的列表项,这时返回到列表页时需要刷新重新获取数据。
我们可以在路由配置文件上对 detail.vue
增加一个 meta
属性。
{
path: '/detail',
name: 'detail',
component: () => import('../view/detail.vue'),
meta: {isRefresh: true}
},
这个 meta
属性,可以在详情页中通过 this.$route.meta.isRefresh
来读取和设置。
设置完这个属性,还要在 App.vue
文件里设置 watch 一下 $route
属性。
watch: {
$route(to, from) {
const fname = from.name
const tname = to.name
if (from.meta.isRefresh || (fname != 'detail' && tname == 'list')) {
from.meta.isRefresh = false
// 在这里重新请求数据
}
}
},
这样就不需要在列表页的 created
函数里用 ajax 来请求数据了,统一放在 App.vue
里来处理。
触发请求数据有两个条件:
- 从其他页面(除了详情页)进来列表时,需要请求数据。
- 从详情页返回到列表页时,如果详情页
meta
属性中的isRefresh
为true
,也需求重新请求数据。
当我们在详情页中删除了对应的列表项时,就可以将详情页 meta
属性中的 isRefresh
设为 true
。这时再返回到列表页,页面会重新刷新。
相关文章
- [转] 在vue中使用SockJS实现webSocket通信
- 【Vue】通过Animate.css实现第三方动画效果示例(图文+实例)
- 【Vue】通过【消息定阅pubsub】实现【任意组件】之间的参数传递(图文+代码示例)
- 【Vue】通过v-show和v-if实现对html元素的隐藏显示渲染(图文+完整示例)
- vue实现文字上下滚动效果
- Vue - 实现信纸输入写作,类似写明信片时的一张背景图片 + 横格纸效果(信纸格子与文字自动对齐、支持自定义背景图、文字或横线大小与颜色,一切由您 DIY 自定义样式)纯CSS完成支持任何vue项目
- Vue - 实现 PC 图片全屏放大预览(支持多图、切换、缩放、旋转、放大缩小、拖动、图片标题、键盘关闭、缩放比例、循环查看等等)
- Vue - 让模板等待接口请求数据完毕后再进行渲染页面(先加载完所有数据再渲染页面)
- Vue - 实现用 JS 调用自定义组件 / 类似 ElementUI 弹框组件(在 js 文件中通过 this.xxx 方式调用并显示自定义弹框模态框组件)
- Vue Router 路由实现原理
- Vue elementUI table 图片 鼠标经过图片放大效果实现
- VUE保存自动格式化
- vue 使用element-ui实现table表单列展示与隐藏
- 基于VUE实现的优鲜食物的移动端购物网站【100010164】
- vue-cli3+cordova实现app混合开发
- vue实战入门后台篇九:springboot+mybatis实现网站后台-代码整合及重构优化
- vue实战入门基础篇三:从零开始仿门户网站实例-公共组件实现
- Vue富文本编辑器的使用vue-quill-deitor
- 基于springboot+vue的“租房平台”程序设计实现【毕业论文,源码】
- Vue项目(vuecli3.0搭建)集成高德地图实现路线轨迹绘制
- 利用vue-meta管理头部标签
- Vue实战第1章:学习和使用vue-router
- Vue实现页面长时间不操作自动退出
- SpringBoot+Vue实现的在线点餐系统 附带详细运行指导视频
- Vuex报错:[vuex] must call Vue.use(Vuex) before creating a store instance.解决方法
- Vue使用第三方库实现动画效果:animate.css使用方法和教程案例
- vue实现标题导航,tab选项卡(一看就会)
- vue中使用better-scroll实现菜单和列表联动的滚动效果,附完整演示代码,(可直接复制)