vue-router next(false) 禁止访问某个页面时,不保留历史访问记录问题

 更新时间:2023年11月16日 15:23:17   作者:爱忽悠的唐唐  
这篇文章主要介绍了vue-router next(false) 禁止访问某个页面时,不保留历史访问记录问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

用户正常访问流程为 产品列表页面【a页面】->产品详情页面(选择不同的计划价格因素后点击购买)【b页面】->产品购买页面【c页面】

下面进行如下操作

c页面 按 <- 返回键 返回了b页面,

而B页面想通过 -> 前进键 回到 c页面。

这样的操作是不被允许的。

于是

我写了如下代码

  /** 防止从填写表单页面后退之后又前进,会丢失之前所选择的计划价格和价格因素 */
  beforeRouteEnter (to, from, next) {
    if (from.name === 'orderInput') {
      sessionStorage.setItem('preventForward', true)
    }
    next()
  },
  beforeRouteLeave (to, from, next) {
    // 如果是从表单填写页返回的并且不是通过购买按钮去往表单填写页面
    if (to.name === 'orderInput' && sessionStorage.getItem('preventForward') === 'true') {
      this.showToast('请点击购买按钮进行购买')
      next(false)
    } else {
      next()
    }
  },
  method:{
	  buy(){
	   sessionStorage.setItem('preventForward', false)
	  }
  }

但是这个操作会有一个问题,当我阻止了一次去往c页面的操作next(false)之后, 如果在b页面 按返回键, 按我们预想的,应该要返回a页面。

可这个时候,实际会返回到 c页面。

原因就是c页面虽然被我们阻止了,却进入了历史栈中, 我想了个方法来防止这个被禁止的请求加入到栈中。

也就是在 next(false) 前面加入

this.$router.go(-1)

整体代码

如下:

beforeRouteEnter (to, from, next) {
  if (from.name === 'orderInput') {
    sessionStorage.setItem('preventForward', true)
  }
   next()
},
beforeRouteLeave (to, from, next) {
  // 如果是从表单填写页返回的并且不是通过购买按钮去往表单填写页面
  if (to.name === 'orderInput' && sessionStorage.getItem('preventForward') === 'true') {
    this.$router.go(-1)
    this.showToast('请点击购买按钮进行购买')
    //这里把next(false)也去掉。兼容移动端。否则在微信操作时,会重复提醒上面那句话
  //  next(false)
  } else {
    next()
  }
},
method:{
    buy(){
     sessionStorage.setItem('preventForward', false)
    }
}

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Vue异步组件处理路由组件加载状态的解决方案

    Vue异步组件处理路由组件加载状态的解决方案

    这篇文章主要介绍了Vue异步组件处理路由组件加载状态的解决方案,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-09-09
  • vue.js+element-ui的基础表单实例代码

    vue.js+element-ui的基础表单实例代码

    这篇文章主要介绍了vue.js+element-ui的基础表单实例代码,技术栈即html+vue.js+element-ui,而使用它们的方法也很简单,引入对应的js和css文件即可,需要的朋友可以参考下
    2024-03-03
  • vue中响应式布局如何将字体大小改成自适应

    vue中响应式布局如何将字体大小改成自适应

    这篇文章主要介绍了vue中响应式布局如何将字体大小改成自适应,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-09-09
  • vue修改数据页面无效的解决方案

    vue修改数据页面无效的解决方案

    这篇文章主要介绍了vue修改数据页面无效的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-06-06
  • windows下vue-cli导入bootstrap样式

    windows下vue-cli导入bootstrap样式

    这篇文章主要介绍了windows下vue-cli导入bootstrap样式,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-04-04
  • vue实现在进行增删改操作后刷新页面

    vue实现在进行增删改操作后刷新页面

    这篇文章主要介绍了vue实现在进行增删改操作后刷新页面,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-08-08
  • Vue实现项目主题切换功能的两种方案详解

    Vue实现项目主题切换功能的两种方案详解

    在现代前端项目开发中,主题切换已成为提升用户体验的核心功能之一,无论是适配用户白天 / 夜间的使用场景、满足企业级产品的品牌定制需求,还是应对不同设备的显示环境,灵活的主题系统都能让产品更具竞争力,所以本文介绍了Vue实现项目主题切换功能的两种方案
    2025-09-09
  • Vue2 Vue-cli中使用Typescript的配置详解

    Vue2 Vue-cli中使用Typescript的配置详解

    Vue作为前端三大框架之一截至到目前在github上以收获44,873颗星,足以说明其以悄然成为主流。下面这篇文章主要给大家介绍了关于Vue2 Vue-cli中使用Typescript的配置的相关资料,需要的朋友可以参考下。
    2017-07-07
  • Vue页面首次载入优化的全过程

    Vue页面首次载入优化的全过程

    凡是做SPA的项目,特别是移动端的SAP项目,首屏加载速度必定是一个绕不过去的话题,下面这篇文章主要给大家介绍了关于Vue页面首次载入优化的相关资料,需要的朋友可以参考下
    2021-12-12
  • 分离vue文件中css、js代码的简单技巧

    分离vue文件中css、js代码的简单技巧

    这篇文章主要给大家介绍了关于分离vue文件中css、js代码的简单技巧,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2022-03-03

最新评论