IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 关于Vue-router中的beforeEach() -> 正文阅读

[JavaScript知识库]关于Vue-router中的beforeEach()

Vue-router中的beforeEach

全局前置守卫

我们可以通过router.beforeEach()来注册一个全局前置守卫:

const router = new VueRouter({ ... })

router.beforeEach((to, from, next) => {
  // ...
})

里面的参数解析:

  • to: Route: 即将要进入的目标 路由对象
  • from: Route: 当前导航正要离开的路由
  • next: 调用 next()方法才能进入下一个路由,否则的如果写了beforeEach方法,但是没有调用next()方法的话,页面会空白,不会跳转到任何页面的。默认不写 router.beforeEach((to, from, next) => {}) 的话,它是默认跳转到指定页面去的,当然如果重写这个方法的话,会覆盖默认的方法。因此如果写了调用了该方法的话,一定需要调用 next()

对于next()里面是可以传入参数的,具体可以看看官网。
这个地方讲一讲next()与next(’/login’)
区别就是前者不会再次调用router.beforeEach(),后者会重新调用一次beforeEach()*(这个地方很关键,因为很容易出现死循环)

实例应用场景:
当验证一个用户是否登录的时候可以使用
代码:

router.beforeEach((to,from,next)=>{
  let isLogin = sessionStorage.getItem('isLogin');
  // console.log(isLogin);
  // console.log(to);
  if(to.path=='/logout'){
    sessionStorage.clear();
    next({path:'/login'})
  }else if(to.path == '/login'){
    if(isLogin){
      next({path:'/main'});
    }else if(isLogin == null){
      // next({path:'/login'}) //这个会出现死循环
      next()
    }
  }

在这里插入图片描述
此时的代码会出现页面不跳转到主页的情况,通过打印to可以看看当前信息,由于next({path:’/main’})导致重新调用了一次beforeEach(),而此时path为/main,会发现与前面的if条件都不匹配,则无法跳转。解决方法则在下面加多一行代码:

router.beforeEach((to,from,next)=>{
  let isLogin = sessionStorage.getItem('isLogin');
  if(to.path=='/logout'){
    sessionStorage.clear();
    next({path:'/login'})
  }else if(to.path == '/login'){
    if(isLogin){
      next({path:'/main'});
    }else if(isLogin == null){
      // next({path:'/login'}) //这个会出现死循环
      next()
    }
  }
  else{
    next(); // 多加这一行了
  }
})

则此时能按照默认跳转的路由进入到最下面的代码段,成功进入主页。

  • 这里还有一个地方容易出现死循环导致错误(注释标出来了)
    还是回归到next()与next(’/login’)的区别,若当isLogin为空的时候,执行的是next({path:’/login’}),会里面重新调用beforeEach(),然后又会因为isLogin为空继续进入里面执行next({path:’/login’}),此时又会重复上述的步骤,一直循环下去,进入死循环。

  • 但如果下面执行的是next()并不会重新调用beforeEach(),直接执行跳转到路由to里面的path。

这问题也就得到解决了。

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-08-07 11:54:23  更:2021-08-07 12:01:38 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 5:53:02-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码