angularjs – ui-router动态模板路径

前端之家收集整理的这篇文章主要介绍了angularjs – ui-router动态模板路径前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我使用的是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事件更为简洁。

猜你在找的Angularjs相关文章