angularjs – ui-router动态模板路径
发布时间:2020-12-17 08:13:35 所属栏目:安全 来源:网络整理
导读:我使用的是ui-router 0.2.8。我想加载基于设备宽度的模板。我可以得到设备宽度没有问题,将其设置在范围等,但我可以弄清楚如何绑定到$ stateParams。我有另一个控制器中的作用域变量,可以访问状态的控制器,它只是不可用于状态本身。我已经尝试了templateP
我使用的是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事件更为简洁。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |