一次router拦截器的应用

实现 退出登陆  无法回退到其它页面

当有登陆状态时  可以拿其它页面的地址直接访问

若没有登陆状态   拿其它页面的地址直接访问 会报错

复制代码
router.beforeEach((to, from, next) => {
  if(to.name=='login'){//若是登陆页面
    if(localStorage.getItem("loginStatus")&&localStorage.getItem("loginStatus")=="login"){//判断是否有登陆状态  若有就免登陆 直接跳到个人信息页
      console.log("有登陆状态的 登陆的首页");
      next({
        name:'personalInfo'
      });
      return;
    }else{
      console.log("无登陆状态的  登陆的首页");
      next();
      return;
    }
  }else{//若不是登录页
    console.log('不是登录页');
    if(localStorage.getItem("loginStatus")&&localStorage.getItem("loginStatus")=="login"){//没登陆状态时 提示地址错误
      next();
      return;
    }else if(to.name=='register'){
      next();
      return;
    }else{
      if(global.ordermark!=''&&global.lang!=''){//有没有ordermark和lang
        var origin=window.location.origin;
        var url;
        if(process.env.NODE_ENV === 'production'){
          url=origin+'/dist/#/'+global.ordermark+'/'+global.lang;
        }else{
          url=origin+'/#/'+global.ordermark+'/'+global.lang;
        }
        window.location.href=url;
        return;
      }else{
        tools.alert("地址错误!请重新登陆");
        return;
      }
    }
  }
  next();
})
复制代码

 

posted @   古墩古墩  Views(310)  Comments(0Edit  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
点击右上角即可分享
微信分享提示