5

我希望我的 durandal 应用程序的每个“区域”都有不同的导航。在使用区域时,我通过在布局页面中定义一个导航部分并使用嵌套布局页面来实现每个区域的导航,从而使用 ASP.NET MVC 实现了这一点。durandal中的视图结构如下:

http://i1346.photobucket.com/albums/p697/user2269352/viewstructure_zps5e21e724.gif

我正在使用 ASP.NET MVC4 durandal 模板,我猜我可能需要从 shell.html 更改以下段

<ul class="nav" data-bind="foreach: router.visibleRoutes">
    <li data-bind="css: { active: isActive }">
        <a data-bind="attr: { href: hash }, html: name"></a>
    </li>
</ul>

我想理想情况下,我希望根据我正在查看的区域/页面,将单独的 html 页面加载到此部分中。

4

2 回答 2

10

您可以通过将设置对象添加到您的路线信息并在那里指定区域名称来完成此操作。有了它,针对路由器的 visibleRoutes 集合创建一个计算的 observable,该集合仅选择当前区域的路由。

不确定您的路由配置是什么样的,但添加设置的示例如下:

var routes = [
    { url: 'one/page1', moduleId: 'viewmodels/one/page1', name: 'Page 1', visible: true, settings: {area: 'one'} },
    { url: 'two/page1', moduleId: 'viewmodels/two/page1', name: 'Page 1', visible: true, settings: {area: 'two'} }
];
router.map(routes);

在您控制导航 html 的视图模型中:

//filter the visible routes for the current area
viewModel.areaRoutes = ko.computed(function () {
    var area = this.area;
    return ko.utils.arrayFilter(router.visibleRoutes(), function (route) {
        return route.settings.area === area;
    });
}, viewModel);
于 2013-04-16T11:58:40.803 回答
1

基于 Joseph Gabriel 的解决方案适用于我并使用router.activeItem.settings.areSameItem我可以在布局中的任何位置设置每条路线的组。

router.activeItem.settings.areSameItem = function (currentItem, newItem, activationData) {
    return currentItem == newItem; //replace this with your own code
};
于 2013-04-30T12:14:28.480 回答