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 相关文章推荐
可以显示单图片,多图片ajax请求的ThickBox3.1类下载
Dec 23 Javascript
JavaScript 关键字屏蔽实现函数
Aug 02 Javascript
isArray()函数(JavaScript中对象类型判断的几种方法)
Nov 26 Javascript
利用jQuery插件扩展识别浏览器内核与外壳的类型和版本的实现代码
Oct 22 Javascript
浅析JavaScript中两种类型的全局对象/函数
Dec 05 Javascript
jQuery模拟黑客帝国矩阵效果实例
Jun 28 Javascript
浅谈js中用$(#ID)来作为选择器的问题(id重复的时候)
Feb 14 Javascript
微信小程序 地图map实例详解
Jun 07 Javascript
js学习心得_一个简单的动画库封装tween.js
Jul 14 Javascript
详解angularjs获取元素以及angular.element()用法
Jul 25 Javascript
JavaScript中时间格式化新思路toLocaleString()
Nov 07 Javascript
vue3不同环境下实现配置代理
May 25 Vue.js
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
萌王史莱姆”萌王性别尴尬!那“萌战”归女组还是男?
2018/12/17 日漫
php中理解print EOT分界符和echo EOT的用法区别小结
2010/02/21 PHP
php表单转换textarea换行符的方法
2010/09/10 PHP
使用PHP实现密保卡功能实现代码<打包下载直接运行>
2011/10/09 PHP
PHP反射机制用法实例
2014/08/28 PHP
Yii 2.0在Grid中格式化时间方法示例
2017/06/06 PHP
Laravel5.5 实现后台管理登录的方法(自定义用户表登录)
2019/09/30 PHP
laravel-admin解决表单select联动时,编辑默认没选上的问题
2019/09/30 PHP
JavaScript 动态添加表格行 使用模板、标记
2009/10/24 Javascript
javascript定义变量时加var与不加var的区别
2014/12/22 Javascript
Jquery 实现grid绑定模板
2015/01/28 Javascript
JS随机调用指定函数的方法
2015/07/01 Javascript
BootStrap文件上传样式超好看【持续更新】
2016/05/10 Javascript
一个简单不报错的summernote 图片上传案例
2016/07/11 Javascript
AngularJS+Bootstrap实现多文件上传与管理
2016/11/08 Javascript
浅谈Vue.js
2017/03/02 Javascript
nodejs 图解express+supervisor+ejs的用法(推荐)
2017/09/08 NodeJs
浅谈angular4.0中路由传递参数、获取参数最nice的写法
2018/03/12 Javascript
Vue+mui实现图片的本地缓存示例代码
2018/05/24 Javascript
JS pushlet XMLAdapter适配器用法案例解析
2020/10/16 Javascript
Python执行时间的计算方法小结
2017/03/17 Python
使用Python的toolz库开始函数式编程的方法
2018/11/15 Python
Python实现投影法分割图像示例(一)
2020/01/17 Python
浅谈pandas.cut与pandas.qcut的使用方法及区别
2020/03/03 Python
详解css3自定义滚动条样式写法
2017/12/25 HTML / CSS
顶级宝石首饰网络零售商:Angara
2016/10/25 全球购物
英国最大的线上保健品零售商之一:Vitamin Planet
2016/12/01 全球购物
路易威登和香奈儿手袋:LuxeDH
2017/01/12 全球购物
安全的后院和健身蹦床:JumpSport
2019/07/15 全球购物
毕业生个人求职的自我评价
2013/10/28 职场文书
日语求职信范文
2013/12/17 职场文书
装饰公司活动策划方案
2014/08/23 职场文书
镇人大副主席民主生活会对照检查材料思想汇报
2014/10/01 职场文书
群众路线自查自纠工作情况报告
2014/10/28 职场文书
飞越疯人院观后感
2015/06/09 职场文书
css让页脚保持在底部位置的四种方案
2022/07/23 HTML / CSS