vue解决mintui中使用MessageBox弹窗拦截,移动端多次点击手机的物理返回键,选择确定后页面返回不正确问题

在Vue项目中使用MintUI的MessageBox时,遇到点击物理返回键或浏览器返回导致页面返回不正确的问题。文章介绍了如何通过在Vuex中设置全局变量并结合`router.beforeEach`来禁止物理返回键控制路由跳转,从而解决在弹窗出现时无法正确返回上一页的状况。同时指出了代码逻辑可能存在不足,但提供了当前解决方案作为临时应对措施。
摘要由CSDN通过智能技术生成

在vue项目中用到mintUI的MessageBox弹窗,不点击取消或者确定键,之后多次在手机(运用android手机上的物理返回键)上进行页面的回退时(或者通过浏览器回退时),返回的页面并不是上一页的页面(详情页面)(点击一次返回按钮时,显示的页面正确)
具体说明:
https://img-blog.csdnimg.cn/59a77a51ed734d4595c9980821ebc634.png

点击确定键时执行后退一步的操作,用手机的物理返回键进行返回,可以返回到上一页面(详情页面),但是不点击确定键的话弹窗本身依然显示,这次单次点击后应返回页面的详情页路由,如下图所示:

这次单次点击后应返回页面的详情页路由(不正确),如下图所示:

在这里插入图片描述

解决这个问题在弹窗出现时禁止使用物理返回键控制路由的跳转

具体实现:
在vuex内定义一个全局的变量来控制这个路由是否可以返回:
vuex中存放:

​const s
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值