Angular4.x通过路由守卫进行路由重定向实现根据条件跳转到相应的页面(推荐)


Posted in Javascript onMay 10, 2018

需求:

最近在做一个网上商城的项目,技术用的是Angular4.x。有一个很常见的需求是:用户在点击“我的”按钮时读取cookie,如果有数据,则跳转到个人信息页面,否则跳转到注册或登录页面

解决

在这里通过Angular的路由守卫来实现该功能。

1. 配置路由信息

const routes = [
 { path: 'home', component: HomeComponent },
 { path: 'product', component: ProductComponent },
 { path: 'register', component: RegisterComponent },
 { path: 'my', component: MyComponent },
 { path: 'login', component: LoginComponent, canActivate: [RouteguardService] },//canActivate就是路由守卫
 { path: '', redirectTo: '/home', pathMatch: 'full' }
]

2. 路由守卫条件(RouteguardService.ts)

import { Injectable, Inject } from "@angular/core";
import { DOCUMENT } from "@angular/common";
import { CanActivate, ActivatedRouteSnapshot, RouterStateSnapshot, Router, NavigationStart } from "@angular/router";
import userModel from "./user.model";

@Injectable()
export class RouteguardService implements CanActivate {
  constructor(private router: Router, @Inject(DOCUMENT) private document: any) {
  }

  canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): boolean {

    // this.setCookie("userId", "18734132326", 10);
    //读取cookie
    var cookies = this.document.cookie.split(";");
    var userInfo = { userId: "", pw: "" };
    if (cookies.length > 0) {
      for (var cookie of cookies) {
        if (cookie.indexOf("userId=") > -1) {
          userModel.accout = cookie.split("=")[0];
          userModel.password = cookie.split("=")[1];
          userModel.isLogin = false;
        }
      }
    }

    //获取当前路由配置信息
    var path = route.routeConfig.path;
    if (path == "login") {
      if (!userModel.isLogin) {
        //读取cookie如果没有用户信息,则跳转到当前登录页
        return true;
      } else {
        //如果已经登录了则跳转到个人信息页面,下面语句是通过ts进行路由导航的
        this.router.navigate(['product'])
      }
    }

  }

  setCookie(cname, cvalue, exdays) {
    var d = new Date();
    d.setTime(d.getTime() + (exdays * 24 * 60 * 60 * 1000));
    var expires = "expires=" + d.toUTCString();
    document.cookie = cname + "=" + cvalue + "; " + expires;
  }
}

总结

以上所述是小编给大家介绍的Angular4.x通过路由守卫进行路由重定向实现根据条件跳转到相应的页面,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
打造个性化的功能强大的Jquery虚拟键盘(VirtualKeyboard)
Oct 11 Javascript
ExpressJS入门实例
Jan 14 Javascript
JS中判断字符串中出现次数最多的字符及出现的次数的简单实例
Jun 03 Javascript
JavaScript和jQuery制作光棒效果
Feb 24 Javascript
jquery仿京东侧边栏导航效果
Mar 02 Javascript
vue-resourse将json数据输出实例
Mar 08 Javascript
JavaScript之underscore_动力节点Java学院整理
Jul 03 Javascript
webpack本地开发环境无法用IP访问的解决方法
Mar 20 Javascript
详解js中Array的方法及技巧
Sep 12 Javascript
bootstrap table合并行数据并居中对齐效果
Oct 17 Javascript
JavaScript两种计时器的实例讲解
Jan 31 Javascript
ES6 Object属性新的写法实例小结
Jun 25 Javascript
JS中的JSON对象的定义和取值实现代码
May 09 #Javascript
js循环map 获取所有的key和value的实现代码(json)
May 09 #Javascript
js合并两个数组生成合并后的key:value数组
May 09 #Javascript
详解Puppeteer 入门教程
May 09 #Javascript
node基于puppeteer模拟登录抓取页面的实现
May 09 #Javascript
nuxt框架中路由鉴权之Koa和Session的用法
May 09 #Javascript
jQuery简单实现的HTML页面文本框模糊匹配查询功能完整示例
May 09 #jQuery
You might like
老照片 - 几十年前的收音机与人
2021/03/02 无线电
Laravel5.1 框架表单验证操作实例详解
2020/01/07 PHP
使用jQuery UI的tooltip函数修饰title属性的气泡悬浮框
2013/06/24 Javascript
javaScript NameSpace 简单说明介绍
2013/07/18 Javascript
javascript中创建对象的几种方法总结
2013/11/01 Javascript
nodejs教程之环境安装及运行
2014/11/21 NodeJs
jQuery中的jQuery()方法用法分析
2014/12/27 Javascript
JS实现在网页中弹出一个输入框的方法
2015/03/03 Javascript
jQuery插件pagination实现分页特效
2015/04/12 Javascript
JS+CSS实现滑动切换tab菜单效果
2015/08/25 Javascript
详解js私有作用域中创建特权方法
2016/01/25 Javascript
js常用的继承--组合式继承
2017/03/06 Javascript
VueJS 集成 Medium Editor的示例代码 (自定义编辑器按钮)
2017/08/24 Javascript
JS删除数组里的某个元素方法
2018/02/03 Javascript
javascript少儿编程关于返回值的函数内容
2018/05/27 Javascript
JS插件clipboard.js实现一键复制粘贴功能
2020/12/04 Javascript
vue项目添加多页面配置的步骤详解
2019/05/22 Javascript
AI小程序之语音听写来了,十分钟掌握百度大脑语音听写全攻略
2020/03/13 Javascript
Python科学计算环境推荐——Anaconda
2014/06/30 Python
wxpython中利用线程防止假死的实现方法
2014/08/11 Python
如何运行.ipynb文件的图文讲解
2019/06/27 Python
Python实现Selenium自动化Page模式
2019/07/14 Python
使用python telnetlib批量备份交换机配置的方法
2019/07/25 Python
python 实现单通道转3通道
2019/12/03 Python
解决python DataFrame 打印结果不换行问题
2020/04/09 Python
python 实现关联规则算法Apriori的示例
2020/09/30 Python
维也纳通行证:Vienna PASS
2019/07/18 全球购物
高中三年学习生活的自我评价
2013/10/10 职场文书
创先争优承诺书范文
2014/03/31 职场文书
出国留学经济担保书
2014/04/01 职场文书
社会稳定风险评估方案
2014/06/02 职场文书
会计系毕业求职信
2014/08/07 职场文书
市贸粮局召开党的群众路线教育实践活动总结大会新闻稿
2014/10/21 职场文书
2015年煤矿工作总结
2015/04/28 职场文书
工作证明格式范文
2015/06/15 职场文书
Spring中的使用@Async异步调用方法
2021/11/01 Java/Android