我的应用程序中有一个主页,每个帖子都有另一个页面,可以通过主页中显示的列表访问。
这就是我的路由器的样子:
var AppRouter = Backbone.Router.extend({
initialize: function(){
this.model = new model();
this.collection = new collection();
},
routes: {
"" : "showForm",
"post/:id" : "showPost"
},
showPost: function(id){
var curmodel = this.collection.get(id);
var post = new postView({model:curmodel});
post.render();
$(".maincontainer").html(post.el);
},
showForm : function(){
var qcView = new qcV({model:this.model, collection:this.collection});
qcView.render()
$(".maincontainer").html(qcView.el);
}
});
这就是此列表中帖子的链接之一的样子
<h2><a id= "<%=_id%>" href="#post/<%=_id%>"><%=name%></h2></a>
我的第一个问题是:以这种方式将页面与基于哈希的 URL 链接起来是否危险?
我的第二个问题是:如果我单击主页中的链接之一,导航到帖子视图没有问题。我的网址成功更改为类似http://127.0.0.1:3000/#post/51ffdb93c29eb6cc17000034
的内容,并且呈现了特定帖子的视图。但是,此时如果我刷新页面,或者直接http://127.0.0.1:3000/#post/51ffdb93c29eb6cc17000034
在我的 URL 栏中键入this.collection.get(id)
,路由器中的 showPost 方法中的方法将返回undefined
。谁能帮我弄清楚为什么会这样?
我检查了几次我的初始化方法都被调用了,并且我的集合和模型被成功创建