我已经开始使用 AngularJS,但在处理路由到嵌套 subview 时遇到了一些麻烦。

我的网站有一个基本的两列布局,如下所示:

[Main 1] [Main 2] [Main 3]
--------------------------------------
A | Content for A goes into this frame.
B |
C |
D |
E |

当您通过主菜单(主菜单 1、主菜单 2、主菜单 3)导航到页面时,侧边菜单链接(a、b、c、d、e)将动态生成。

即,导航到 main1 链接将向 /main1 发出请求,该请求将返回链接的 JSON 数组。

当用户单击这些链接之一时,它将向 /main1/a 发出请求并将数据加载到内容框架中。

我目前这样做的方式是:

index.html:
<body>
    <a href="/main1">Main 1</a>

    <div ng-view></div>
</body>

app.js:
angular.module('test', [
    'test.controllers'
])

.config([
    '$routeProvider',

    function($routeProvider)
    {
        $routeProvider
            .when('/main1', {
                templateUrl: '/partials/main1.html',
                controller:  'Main1Ctrl'
            })
            .when('/main1/:id', {
                templateUrl: '/partials/main1.html',
                controller:  'Main1Ctrl'
            })
    }
]);

这就是我陷入困境的地方。我的 Main1Ctrl Controller 目前看起来像:
angular.module('test.controllers', [])

.controller('Main1Ctrl', [
    '$scope',
    '$routeParams',
    'Data',

    function($scope, $routeParams, Data)
    {
        $scope.submenu = Data.query();
    }
]);

我遇到的问题是如何分配 $scope.content

如果在 URL 中没有指定 ID,我将需要等待子菜单呈现,然后才能从列表中获取第一个 ID(如果没有请求内容,它将默认为第一个子菜单项)。

如果用户在 URL 中指定了一个 ID,我希望 /main1/main1/:id 请求并行触发。用户在看到他们的内容之前不应该需要等待菜单加载。

这甚至是处理这种布局的好方法吗?

最佳答案

我利用路由提供程序和变量创建了一个可以在任何地方访问的全局对象。然后,您可以使用 ng-show/hide、ng-switch 或 ui-if 来显示或隐藏或切换应用程序的适用部分,以实现多级深层链接。

看看我 build 的这个plunker。它会告诉你如何做到这一点。

http://plnkr.co/edit/beAm3WRomMafKzx1SoSZ?p=preview

关于javascript - 如何使用 AngularJS 路由到 subview ?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/14311726/

10-11 08:11