我们在同一个 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 实例 - 所以一个实例设置了处理程序而另一个没有
谢谢,大卫!