我使用的是ui-router 0.2.8。我想加载基于设备宽度的模板。我可以得到设备宽度没有问题,将其设置在范围等,但我可以弄清楚如何绑定到$ stateParams。我有另一个控制器中的作用域变量,可以访问状态的控制器,它只是不可用于状态本身。我已经尝试了templateProvider,但这只是给我一个字符串。为了工作,我还可以尝试什么?
.state('list',{ abstract: true,url: "/list",templateUrl: 'views/'+$stateParams.somevalue+'/page.html',controller: "myCtrl" }) .state('list.first',{ url: "/first",templateUrl: "views/first.html" })
您可以访问$ stateChangeStart事件中的状态参数。您也可以在此动态更新templateUrl。
所以也许你的代码可能看起来像这样:
angular.module('app',['ui.router']) .run(function($rootScope){ $rootScope.$on('$stateChangeStart',function(event,toState,toParams) { if (toState.name === 'list') { toState.templateUrl = 'views/'+toParams.somevalue+'/page.html'; } }); }
你可能还想看看ui.router支持的onEnter callback。我以前没有使用过,但可能比将您的模板生成代码放入$ stateChangeStart事件更为简洁。