-
在使用uniapp的原生返回的按钮时,如果没有刷新会正常返回到对应的页面,如果刷新后会在当前页反复横跳,或者跳转到登录页。
-
那个时候我第一个想法时:使用浏览器的history.back()方法。因为浏览器刷新后还是可以通过右上角的返回按钮进行返回的。
-
然后我通过uniapp的addInterceptor或者onBackPress进行劫持点击返回时的事件。


-
可惜经过刷新后的后退按钮完全没有调用这两个回调。
-
这个时候我发现如果刷新后点击回退后会调用reLaunch的方法。

-
所以我在reLaunch判断,如果是uniapp自动调用的reLaunch这个方法。我就return false,并调用 history.back()方法返回上一个页。
javascriptuni.addInterceptor("reLaunch", { invoke(e) { // 因为刷新后进行后退会调用这个路径,所以需要劫持然后调用back方法。 if (e.url == "/") { history.back(); return false; } }, }); -
当然这个是浏览器才有的问题,如果是原生app,不会有刷新的功能。加这个逻辑的时候记得判断是不是原生app,可以通过是否有plus这个属性来进行判断是哪一个环境。
处理uniapp刷新后,点击返回按钮跳转到登录页的问题
姚*鸿的博客2024-07-18 21:13
相关推荐
2501_9159090614 小时前
手机崩溃日志导出的工程化体系,从系统级诊断到应用行为分析的多工具协同方法郑州光合科技余经理15 小时前
技术视角:海外版一站式同城生活服务平台源码解析wangdaoyin201017 小时前
UniApp中使用LivePlayer进行视频或在流媒体播放2501_9151063217 小时前
App HTTPS 抓包实战解析,从代理调试到真实网络流量观察的完整抓包思路游戏开发爱好者819 小时前
苹果App Store应用程序上架方式全面指南2501_9160088919 小时前
深入理解 iPhone 文件管理,从沙盒结构到开发调试的多工具协同实践一室易安20 小时前
解决使用 UniApp 搭配 Vue3 小程序开始 使用uview-plus 的返回顶部up-back-top中onPageScroll 不触发的问题yilan_n20 小时前
鸿蒙应用上传yilan_n20 小时前
【UniApp实战】手撸面包屑导航与路由管理 (拒绝页面闪烁)一室易安20 小时前
uniapp+vue3 微信小程序中 页面切换tab 页面滚动到指定锚点位置,滚动页面时候到达指定锚点位置吸顶tab 会自动进行切换