DurandalJS路由行为

时间:2013-04-15 01:36:40

标签: javascript knockout.js single-page-application durandal

我有什么

试图了解正在发生的事情以及如何控制它。对于尚未经过身份验证的用户,我有一个“公共”视图,对于经过身份验证的用户,我有一个“主页”视图。这是我的路线配置:

app.start().then(function() {
        //Replace 'viewmodels' in the moduleId with 'views' to locate the view.
        //Look for partial views in a 'views' folder in the root.
        viewLocator.useConvention();

        //configure routing
        router.useConvention();

        router.mapRoute('home', 'viewmodels/home', 'Test App', true);
        router.mapRoute('public', 'viewmodels/public', 'Test App', true);
        router.mapRoute('set/:id', 'viewmodels/set', 'Set');
        router.mapRoute('folder/:id', 'viewmodels/folder', 'Folder');
        router.mapRoute('api', 'viewmodels/api', 'API Reference');
        router.mapRoute('error', 'viewmodels/error', 'Error', false);
        app.adaptToDevice();

        //Show the app by setting the root view model for our application with a transition.

        if (dataservice.isAuthenticated() === true) {
            app.setRoot('viewmodels/shell', 'entrance');
            router.navigateTo('home');
        } else {
            app.setRoot('viewmodels/public');
            router.navigateTo('#/public');
        }

        router.handleInvalidRoute = function (route, params) {
            logger.logError('No route found', route, 'main', true);
            router.navigateTo('#/error');
        };
    });

问题

当我第一次运行应用程序时,我没有通过身份验证,并且出现错误:

Uncaught TypeError: Cannot call method 'lookupRoute' of undefined 

来自'router.navigateTo('#/public');'行。

然后,当我尝试单击登录按钮时,我得到了相同的错误:

define(['durandal/app', 'durandal/plugins/router', 'services/dataservice'], function (app, router, dataservice) {
   var publicViewModel = function () {
        self.logIn = function () {
            app.setRoot('viewmodels/shell');
            router.navigateTo('#/home');
        };

但内容加载正确。当我通过单击导航到特定页面时,说到/ folder / 2,然后将URL更改为/ folders / 2(无效),我按照预期在我的日志中找到“找不到路由”,但我遇到了其他一些问题:

  1. 我没有收到错误页面或任何错误(我想我应该根据我的handleInvalidRoute)
  2. 如果我点击其他内容,则网址不会更改,并且不会加载新内容,同样没有错误。
  3. 我认为我在某种程度上打破了路由,但我不确定如何。我该如何纠正上述问题?

    屏幕:

    enter image description here

1 个答案:

答案 0 :(得分:1)

我怀疑为了某种原因,你可能会因为太快而调用导航器。要测试这个理论,请尝试移动此代码。

    if (dataservice.isAuthenticated() === true) {
        app.setRoot('viewmodels/shell', 'entrance');
        router.navigateTo('home');
    } else {
        app.setRoot('viewmodels/public');
        router.navigateTo('#/public');
    }

进入"激活"你的publicviewmodel和main.js中的方法就是这样:

app.setRoot('viewmodels/public');

编辑:旧建议

我相信你的viewmodel你需要一个路由器属性。因此,修改您的公共视图模型以添加一个:

define(['durandal/app', 'durandal/plugins/router', 'services/dataservice'], function (app, router, dataservice) {
   var publicViewModel = function () {
        self.router = router;
        self.logIn = function () {
            app.setRoot('viewmodels/shell');
            router.navigateTo('#/home');
        };

(你在哪里定义自己?)