标签:pos mst ram test 本地 方法 function ext token
//监控路由转换 $rootScope.$on(‘$stateChangeStart‘, function(event, toState, toParams, fromState, fromParams) {//上面的参数是固定的 if(toParams.name === ‘quanCheck‘ && !$sessionStorage.userInfo) { //进入O2O卡券验证页面 event.preventDefault();//该方法是阻止页面进入先进行下面的判断 //验证token信息是否合法,合法则跳到卡券验证界面 Service.post(‘users‘, ‘verifyToken‘, { sysId: systemId.o2O, token: toParams.param }).then(function(data) { $sessionStorage.userInfo = angular.extend(data.dataInfo, { currentSystemId: systemId.o2O }); $state.go(‘o2O‘, { parent: ‘verify‘, name: ‘quanCheck‘, param: null }); }, function(error) { $state.go(‘o2OLogin‘); }); } else if(notCheckLoginStates.indexOf(toState.name) < 0 && !$sessionStorage.userInfo) { //防止用户不登录直接进入功能模块 event.preventDefault(); $state.go(localStorage.defaultLoginState || ‘chooseSystem‘); swal(‘请先‘ + (localStorage.defaultLoginState ? ‘登录!‘ : ‘选择系统!‘), ‘‘, ‘error‘); } //删除会话储存数据 if(deleteStorageStates.indexOf(toState.name) >= 0) { delete $sessionStorage.userInfo; delete $sessionStorage.systemInfo; } //删除本地预设登录数据 if(toState.name === ‘chooseSystem‘) { localStorage.removeItem(‘defaultLoginState‘); } });
三、angularjs 如何在页面没有登录的情况下阻止用户通过更改url进入页面--$stateChangeStart
标签:pos mst ram test 本地 方法 function ext token
原文地址:http://www.cnblogs.com/gunelark/p/7290513.html