处理uniapp刷新后,点击返回按钮跳转到登录页的问题

  1. 在使用uniapp的原生返回的按钮时,如果没有刷新会正常返回到对应的页面,如果刷新后会在当前页反复横跳,或者跳转到登录页。

  2. 那个时候我第一个想法时:使用浏览器的history.back()方法。因为浏览器刷新后还是可以通过右上角的返回按钮进行返回的。

  3. 然后我通过uniapp的addInterceptor或者onBackPress进行劫持点击返回时的事件。

  4. 可惜经过刷新后的后退按钮完全没有调用这两个回调。

  5. 这个时候我发现如果刷新后点击回退后会调用reLaunch的方法。

  6. 所以我在reLaunch判断,如果是uniapp自动调用的reLaunch这个方法。我就return false,并调用 history.back()方法返回上一个页。

    javascript 复制代码
      uni.addInterceptor("reLaunch", {
        invoke(e) {
          // 因为刷新后进行后退会调用这个路径,所以需要劫持然后调用back方法。
          if (e.url == "/") {
            history.back();
            return false;
          }
        },
      });
  7. 当然这个是浏览器才有的问题,如果是原生app,不会有刷新的功能。加这个逻辑的时候记得判断是不是原生app,可以通过是否有plus这个属性来进行判断是哪一个环境。

相关推荐
雪芽蓝域zzs33 分钟前
uniapp 获取app版本信息(兼容鸿蒙)
uni-app
一颗小青松44 分钟前
uniapp app端使用uniCloud云函数和云对象
uni-app
2501_916008892 小时前
在 Windows 上使用开心上架(Appuploader)在 Windows 环境下创建与管理 iOS 证书
android·ios·小程序·https·uni-app·iphone·webview
qq_316837753 小时前
uniapp打包的微信小程序和h5两个项目 微信小程序webview打开h5 ,h5发送消息到小程序
微信小程序·小程序·uni-app
fxshy4 小时前
uniapp结合uniCloud开发的微信小程序,在开发本地接口可以正常,但是线上异常,配置服务器域名解决
微信小程序·小程序·uni-app
技术宅小温4 小时前
< uni-app开发核心难点解析:框架适配与打包发布全流程踩坑指南 >
前端·前端框架·uni-app·web app
宠友信息16 小时前
面向多端部署的社区平台技术方案:uniapp 与java微服务架构的工程化实践
java·微服务·微信·架构·uni-app·springboot
2501_9159214320 小时前
没有 iOS 源码的前提下如何进行应用混淆,源码混淆失效后的替代
android·ios·小程序·https·uni-app·iphone·webview
2501_915106321 天前
Perfdog 成本变高之后,Windows 上还能怎么做 iOS APP 性能测试
android·ios·小程序·https·uni-app·iphone·webview
奶糖 肥晨1 天前
JS自动检测用户国家并显示电话前缀教程|vue uniapp react可用
javascript·vue.js·uni-app