javascript - 为每个 md-tab 实现单独的 Controller 的问题

标签 javascript angularjs angular-ui-router angular-material

我的模板 HTML 文件“testview.html”如下所示:

<div class="container-fluid">
    <md-toolbar>
        <h2 class="md-toolbar-tools">
            <span>Test View</span>
        </h2>
    </md-toolbar>
    <md-tabs md-stretch-tabs
             md-selected="selectedIndex">
        <md-tab label="basicConfig">
        </md-tab>
        <md-tab label="awardSettings">
        </md-tab>
    </md-tabs>

    <div id="content" ui-view flex> </div>
</div>

这是我的路由 Controller “testview.js”:

angular
.module('app.testview')
.controller('TestView', TestView)
.config(['$stateProvider', function ($stateProvider) {
    $stateProvider
    .state('basicConfig', {
        url: '/basicConfig',
        templateUrl: 'app/testview/testview_partials/basicConfig.html',
        controller: 'BasicConfig as vm'
    })
    .state('awardSettings', {
        url: '/awardSettings',
        templateUrl: 'app/testview/testview_partials/awardSettings.html',
        controller: 'AwardSettings as vm'
    })
}]);

TestView.$inject = ['$state', '$scope', '$location'];

function TestView(state, $scope, $location) {
    $scope.selectedIndex = -1;

    $scope.$watch('selectedIndex', function(current, old) {
        switch (current) {
            case 0:
                $location.url("/basicConfig");
                break;
           case 1:
                $location.url("/awardSettings");
                break;
        }
    });

}

这是我的 awardSettings.html 的样子:

<form name="awardSettingsForm" id="awardSettingsForm">
    <md-content flex layout-padding layout="row" layout-sm="column" layout-align-sm="space-between start" layout-align="space-between center">
        <label style="font-size: 24px;">Award Settings</label>
    </md-content>
</form>

我在单独的文件中定义了 basicConfig 和 awardSettings html 和 Controller 。我知道我的路线工作正常。但我的问题是我想要 basicConfig.html 和 awardSettings.html 的内容在它们的选项卡中。但这是行不通的。当我点击选项卡时,它看起来像下面 enter image description here

enter image description here

如有任何帮助,我们将不胜感激。谢谢!

最佳答案

没关系。我弄清楚我做错了什么。必须将子状态更改为主状态的一部分,即。将状态从“basicConfig”更改为“testview.basicConfig”。

function stateConfig ($stateProvider, $urlRouterProvider) {
$stateProvider
  .state('testview.basicConfig', {
    templateURL: 'app/testview/testview_partials/basicConfig.html',
    controller: 'BasicConfig'
  })
  .state('testview.awardSettings', {
    template: '<h3>Award!!</h3>',
    controller: 'AwardSettings'
  })

关于javascript - 为每个 md-tab 实现单独的 Controller 的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38362852/

相关文章:

javascript - 如何限制 ng-repeat 中的迭代

javascript - $watch 只触发一次

javascript - 无法删除 AngularJS 中的 #

具有延迟加载模块的 Angular 路由器面包屑

javascript - 测试 angularjs ui-router go() 方法

javascript - 未捕获的类型错误 : Cannot use 'in' operator to search for '' in JSON string

javascript - 在 Node.js 中注册成功后直接进行身份验证(登录)

javascript - 是否可以在 Node REPL 中运行 ES6?

angularjs - 重置文件选择 blueimp fileupload - angularJS

javascript - 类型 'Function' 的参数不可分配给类型 'ComponentType<never>' 的参数