我是靠谱客的博主 魁梧丝袜,这篇文章主要介绍angular 未登录状态拦截路由跳转的方法,现在分享给大家,希望可以做个参考。

使用angularjs的但页面应用时,由于是本地路由在控制页面跳转,但是有的时候我们需要判断用户是否登录来判断用户是否能进入界面。

angularjs是mvc架构所以实现起来很容易也很灵活,我们只MainController里增加一个路由事件侦听并判断,这样就可以避免未登录用户直接输入路由地址来跳转到登录界面地址了。

第一步:定义myapp

复制代码
1
var myapp=angular.module("MainController",["ui.router",'infinite-scroll','oc.lazyLoad']);

第二步:使用config来配置路由跳转

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
myapp.config( function($stateProvider,$urlRouterProvider,$ocLazyLoadProvider,$httpProvider){ $stateProvider .state('index', {//首页 url: '/index', templateUrl: basePath+'page/gym/lecycle_index.html', resolve: { loadMyCtrl: ['$ocLazyLoad', function($ocLazyLoad){//这两行就是loader的使用,此行写法固定 return $ocLazyLoad.load(basePath+'src/lecycle_index/le_index.js');//后面这个就是进入这个模板时候要加载进来的js }] } }) .state('userAgree',{//同意用户协议页面 url:"/userAgree", templateUrl:basePath+'page/agreement.html' }) ....... $urlRouterProvider.otherwise("/index");/*BproDtails*/ });

第三步:使用run来进行登录验证拦截

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
myapp.run(function ($rootScope,$state) { $rootScope.$on('$stateChangeStart',function(event){ // if(toState.name=='login')return;// 如果是进入登录界面则允许 // 如果用户不存在 if(ifLoginTrue==false){ console.log("没有登录") event.preventDefault();// 取消默认跳转行为 $("#my-modal-loading").modal('open');//开启加载中loading // $state.go("login",{from:fromState.name,w:'notLogin'});//跳转到登录界面 } }); });

以上这篇angular 未登录状态拦截路由跳转的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持靠谱客。

最后

以上就是魁梧丝袜最近收集整理的关于angular 未登录状态拦截路由跳转的方法的全部内容,更多相关angular内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(204)

评论列表共有 0 条评论

立即
投稿
返回
顶部