项目经理要求不能回退到项目以外的路由 , 简单解决 !

不知道小伙伴们有遇到过项目经理哪些奇奇怪怪的需求呢 ?

  • 曾经在项目中遇到过这样一个需求 : 点击按钮回退时不能回退到项目以外的路由 ;
  • 例如我们的用户正在访问我们的页面时 , 突然有访问某个有趣的网站的冲动 , 在浏览器输入了一串祖传网址 , 一番欣赏后通过浏览器搜索栏回到我们的应用中 , 又点击了我们应用中的回退按钮 , 要求不能回退到用户刚才访问的项目外地址 。

router编程式导航

首先先回顾一下router的两个回退方法(Vue2用法) :

  • this.$router.back() --回退
  • this.$router.go(-1) --前进或后退 , 值为-1时后退
router 复制代码
// Vue3用法
// 1. 引入 useRouter 方法
import { useRouter , useRoute } from 'vue-router'
// 2. 实例化router
const router = useRouter()
// 3. 使用方法进行回退
router.back()

history全局对象

我们怎样知道刚才访问的页面是否为项目中配置的路由呢 ?

history对象 !!

  • history对象是浏览器提供的一个全局对象,它包含了浏览器的浏览历史记录
  • history.state : history提供了state属性 , 返回当前历史状态对象

我们在点击返回按钮时可以在控制台查看一下history.state 属性

当我们使用项目外的网站跳转至项目路由再进行回退 :

我们可以看到state中有一个back属性 , 当外部网站跳转回来时history.state.back值为null

那么项目内部相互跳转再进行回退是什么效果呢 ?

我们可以看到state中的back值为/login , 那么我们就可以用小back来做判断了

history 复制代码
// 回退按钮
    <button @click="onClickBack">返回</button>
<templete>
  
</templete>
// 点击返回按钮事件函数
        const onClickBack = () => {
                  //1. console.log(history) 可以试打印一下history对象
                  if ( history.state?.back ) {
                  //2. 如果history.state?.back不为null , 返回上一个页面
                         router.back()
                  } else {
                  //3. 否则返回主页面
                         router.push('/')
                  }
               }

拓展: 可选链

  • 上面代码中我们用到了history.state?.back, 上文我们有提到history.state?.back的值有可能为null , 所以会发生找不到back属性的情况 ;
  • 我们可以使用ES2021可选链, 当然也可以使用条件判断或三元运算符等方法 , 相较而言可选链更加便捷一些 ;
  • ES2021(也称为ES12)是JavaScript的最新版本,于2021年6月发布。

以上是我解决此问题的方案 , 小伙伴们有什么更好的方案可以一起探讨一下下~

相关推荐
tedcloud1231 小时前
UI-TARS-desktop部署教程:构建AI桌面自动化系统
服务器·前端·人工智能·ui·自动化·github
Mahir084 小时前
Redis 与 MySQL 数据同步:一致性保证的完整解决方案
数据库·redis·mysql·缓存·面试·数据一致性
UXbot4 小时前
AI原型设计工具如何支持团队协作与快速迭代
前端·交互·个人开发·ai编程·原型模式
ZC跨境爬虫5 小时前
跟着MDN学HTML_day_48:(Node接口)
前端·javascript·ui·html·音视频
刀法如飞6 小时前
Go 字符串查找的 20 种实现方式,用不同思路解决问题
算法·面试·程序员
PieroPc6 小时前
CAMWATCH — 局域网摄像头监控系统 Fastapi + html
前端·python·html·fastapi·监控
巴巴博一7 小时前
2026 最新:Trae / Cursor 一键接入 taste-skill 完整教程(让 AI 前端告别“AI 味”)
前端·ai·ai编程
kyriewen8 小时前
半夜三点线上崩了,AI替我背了锅——用AI排错,五分钟定位三年老bug
前端·javascript·ai编程
kyriewen8 小时前
我让 AI 当了 24 小时全年无休的“毒舌考官”
前端·ci/cd·ai编程
hexu_blog8 小时前
vue+java实现图片批量压缩
java·前端·vue.js