1

我的应用程序中有一个主页,每个帖子都有另一个页面,可以通过主页中显示的列表访问。

这就是我的路由器的样子:

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。谁能帮我弄清楚为什么会这样?

我检查了几次我的初始化方法都被调用了,并且我的集合和模型被成功创建

4

2 回答 2

3

对于#2,您很可能不会在“发布”路线上获取集合。尝试获取集合(如果它不存在),然后调用 render. 这应该够了吧!

于 2013-08-05T17:59:40.980 回答
2

我认为@Trunal 在第二个问题上是正确的。首先,不,这不是“危险的”。与经典的服务器端应用程序相比,您并没有真正做任何不同的事情,通过 GET 将信息传递到服务器以检索信息。在我看来,这应该是实现路由的首选方法(而不是尝试backbone.history.navigate手动触发,因为它避免了可能发生的各种设置和事件问题)。

于 2013-08-05T18:21:22.047 回答