零件和模板的复杂嵌套

JavaScript

Jim理查德猿

2020-03-12

我的问题涉及到如何在AngularJS应用程序中处理模板的复杂嵌套(也称为partials)。

描述我的情况的最好方法是使用创建的图像:

AngularJS页面图

如您所见,这有可能成为具有许多嵌套模型的相当复杂的应用程序。

该应用程序是单页的,因此它将加载index.html索引包含DOM中具有ng-view属性的div元素

对于第1圈,您看到有一个主导航将相应的模板加载到中ng-view我通过传递$routeParams给主应用程序模块来实现此目的。这是我的应用程序中的一个示例:

angular.module('myApp', []).
    config(['$routeProvider', function($routeProvider) {
        $routeProvider.                     
            when("/job/:jobId/zones/:zoneId", { controller: JobDetailController, templateUrl: 'assets/job_list_app/templates/zone_edit.html' }).
            when("/job/:jobId/initial_inspection", { controller: JobDetailController, templateUrl: 'assets/job_list_app/templates/initial_inspection.html' }).
            when("/job/:jobId/zones/:zoneId/rooms/:roomId", { controller: JobDetailController, templateUrl: 'assets/job_list_app/templates/room_edit.html' })       

    }]);

在第2圈中,加载到中的模板ng-view具有附加的子导航然后,该子导航需要将模板加载到其下方的区域中-但由于已使用ng-view,因此我不确定如何执行此操作。

我知道我可以在第一个模板中包含其他模板,但是这些模板都将非常复杂。我想将所有模板分开,以使应用程序更易于更新,并且不依赖于必须加载父模板才能访问其子模板。

在第3圈中,您会看到事情变得更加复杂。子导航模板可能会具有第二个子导航,这需要将其自己的模板以及第4圈的区域加载

如何构建一个AngularJS应用程序以处理模板的这种复杂嵌套,同时又将它们彼此分开呢?

第1206篇《零件和模板的复杂嵌套》来自Winter(https://github.com/aiyld/aiyld.github.io)的站点

2个回答
神奇Harry 2020.03.12

您可以使用ng-include来避免使用嵌套的ng-views。

http://docs.angularjs.org/api/ng/directive/ng包含
http://plnkr.co/edit/ngdoc:example-example39@snapshot?p=preview

我的索引页面使用ng-view。然后在我的子页面上,我需要使用嵌套框架。我使用ng-include。该演示显示了一个下拉列表。我用链接ng-click替换了我的。在函数中,我将$ scope.template = $ scope.templates [0]; 或$ scope.template = $ scope.templates [1];

$scope.clickToSomePage= function(){
  $scope.template = $scope.templates[0];
};
神无凯 2020.03.12

Angular ui-router支持嵌套视图。我还没有使用过,但是看起来很有希望。

http://angular-ui.github.io/ui-router/

问题类别

JavaScript Ckeditor Python Webpack TypeScript Vue.js React.js ExpressJS KoaJS CSS Node.js HTML Django 单元测试 PHP Asp.net jQuery Bootstrap IOS Android