0

我们在同一个 MVC 应用程序中有多个单页应用程序。我们正在使用 Backbone/Marionette,并且路由似乎不起作用(从不触发默认的 Route 操作)。

编码:

QaApp.module("QaApp", function (Mod, App, Backbone, Marionette, $, _) {
    QaApp.Router = Marionette.AppRouter.extend(
        {
            appRoutes: {
                '' : 'subscribe',
                ':id': 'subscribe',
                '/qa/index/:id': 'subscribe'
            }
        });

    var Api = {
        subscribe: function (id) {
            //never fires
            console.log("subscribing with id = " + id);
            QaApp.Lightstreamer.Do('subscribeUpdate', {
                adapterName: 'QaAdapter',
                field: ['jsonString', 'firstData'],
                parameterValue: id,
                onUpdate: load
            });
        },
        load: function (data) {
            var question = new QaApp.Question({ id: data.id, collection: data.messages });
            var questionView = new QaApp.QuestionView(question);
            QaApp.page.show(questionView);
        }
    };

    QaApp.addInitializer(function () {
        var router = new QaApp.Router(
        {
            controller: Api
        });
        console.log(router.appRoutes);
    });
});

标准路由器似乎假设您的根 url 是http://localhost或者,如果不是,则路由是 # 之后的任何内容(无论如何都找不到好的文档)。

所以,对我们来说,当您登陆页面时,网址可能是:

http://localhost/qa/index/1其中控制器是“qa”,视图是“index”,id 是 1。

我希望我的“订阅”操作在这个默认 url 上触发并将“id”作为参数。

我应该使用什么路线?

注意:根据这篇文章,我已经验证了在初始化程序运行后调用了 Backbone.history.start()。

另请注意:在 appRoutes 下是我尝试过的所有不同路线。我知道我只需要一个,只要我能找到合适的。

提前致谢!

更新:单步执行主干代码,“this.handlers”似乎是一个空数组,因此 url 似乎永远无法匹配。

基于更新答案的更新:传入根确实使骨干认识到我在根,所以我更接近,但在下面的片段中,“片段”是“”,this.handlers 是一个长度为 0 的数组,并且“匹配”返回 false:

loadUrl: function (fragmentOverride) {
            var fragment = this.fragment = this.getFragment(fragmentOverride);
            var matched = _.any(this.handlers, function (handler) {
                if (handler.route.test(fragment)) {
                    handler.callback(fragment);
                    return true;
                }
            });
            return matched;
        }

最终更新:处理程序为空是问题所在,结果是由于页面上部分加载了第二个主干.js 实例 - 所以一个实例设置了处理程序而另一个没有

谢谢,大卫!

4

1 回答 1

5

如果您不想在 URL 中包含“#”,则需要使用 pushState

Backbone.history.start({pushState: true });

请注意,要使其正常工作,您的 Backbone 应用程序可以生成的每个 URL 都必须存在于服务器上。换句话说,服务器必须为它可以访问的每个 URL 返回一个有效页面给您的应用程序。每个 URL 的内容不必不同(您可以发送index.html包含您的应用程序的相同内容并让 Backbone 处理应该显示的内容),但需要向客户端发送一些内容。

根据评论编辑:

它没有按预期运行的原因是因为您用于启动 Backbone 应用程序的任何页面默认情况下都是它的根 URL,因此不会执行任何路由。尝试root在启动历史记录时设置属性(请参阅http://backbonejs.org/#History-start

于 2013-09-05T09:18:19.157 回答