加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

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事件更为简洁。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读