分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 网页技术

angular 的ui.router 定义不同的state 对应相同的url

发布时间:2023-09-06 01:29责任编辑:董明明关键词:url

Angular UI Router: Different states with same URL?

The landing page of my app has two states: home-publichome-logged-in. Now I want to show both states on the same URL, but let the controller and template depend on the user session (is the user logged in or not?).

Is there a way to achieve this?

----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

You could have a base state that controls which state to load, and you could simply have the child stated of that base state not have urls:

.state(‘home‘, { ?url: "/home", ?templateUrl: "....", ?controller: function($scope,$state,authSvc) { ????if(authSvc.userIsLoggedIn()){ ?????????$state.go(‘home.loggedin‘) ????}else{ ?????????$state.go(‘home.public‘) ????} ?}}).state(‘home.public‘, { ?url: "", ?templateUrl: "....", ?controller: function($scope) { ????........... ?}}).state(‘home.loggedin‘, { ?url: "", ?templateUrl: "....", ?controller: function($scope) { ????........... ?}})

Now in the controller of your base state (home) you can check if the user is logged in or not, and use $state.go() to load an appropriate state.

angular 的ui.router 定义不同的state 对应相同的url

原文地址:http://www.cnblogs.com/oxspirt/p/7995043.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved