2012-07-19 126 views
0

我一直在使用Backbone.LayoutManager处理原型骨干应用程序,我遇到了一些我不明白的东西。Backbone.LayoutManager委托视图事件

这种情况是我有一个表格,用于将“people”{firstname,lastname}添加到列表视图中,我将模型保存好并且新项目显示在列表中。我也有一个删除功能,在刷新页面后工作,但如果我尝试删除刚刚创建的用户而不进行页面刷新,则removeUser()函数永远不会被调用。

我的代码如下。有人可以帮我吗?我只是想学习Backbone,如果你有这个问题的答案以及其他任何批评,我会很感激。谢谢。

define([ 
    // Global application context. 
    "app", 

    // Third-party libraries. 
    "backbone" 
], 

function (app, Backbone) { 
    var User = app.module(); 

    User.Model = Backbone.Model.extend({ 
     defaults : { 
      firstName: "", 
      lastName: "" 
     } 
    }); 

    User.Collection = Backbone.Collection.extend({ 
     model: User.Model, 
     cache: true, 
     url: "/rest/user" 
    }); 

    User.Views.EmptyList = Backbone.View.extend({ 
     template: "users/empty-list", 
     className: "table-data-no-content", 
     render: function (manage) { 
      return manage(this).render().then(function() { 
       this 
        .$el 
        .insertAfter(".table-data-header") 
        .hide() 
        .slideDown(); 
      }); 
     } 
    }); 

    User.Views.Item = Backbone.View.extend({ 
     template: "users/user", 
     tagName: "ul", 
     className: "table-data-row" 
     events: { 
      "click .remove": "removeUser" 
     }, 
     removeUser: function() { 
      console.log(this.model); 
      this.model.destroy(); 
      this.collection.remove(this.model); 
      this.$el.slideUp(); 
      if (this.collection.length === 0) { 
       this.insertView(new User.Views.EmptyList).render(); 
      } 
     } 
    }); 

    User.Views.List = Backbone.View.extend({ 
     initialize: function() { 
      this.collection.on("change", this.render, this); 
     }, 
     render: function (manage) { 
      if (this.collection.length > 0) { 
       jQuery(".table-data-no-content").slideUp("fast", function() { 
        $(this).remove(); 
       }); 
       this.collection.each(function(model) { 
        this.insertView(new User.Views.Item({ 
         model: model, 
         collection: this.collection, 
         serialize: model.toJSON() 
        })); 
       }, this); 
      } else { 
       this.insertView(new User.Views.EmptyList()); 
      } 

      // You still must return this view to render, works identical to 
      // existing functionality. 
      return manage(this).render(); 
      } 
    }); 

    User.Views.AddUser = Backbone.View.extend({ 
     template: "users/add-user", 
     events: { 
      "click input#saveUser": "saveUser" 
     }, 
     render: function (manage) { 
      return manage(this).render().then(function() { 
       $("input[type='text']") 
        .clearField() 
        .eq(0) 
        .focus(); 
      }); 
     }, 
     saveUser: function() { 
      var user = new User.Model({ 
       firstName: $(".first-name").val(), 
       lastName: $(".last-name").val() 
      }); 

      this.collection.create(user); 

      this 
       .$("input[type='text']") 
       .val("") 
       .clearField("refresh") 
       .removeAttr("style") 
       .eq(0) 
       .focus(); 
     } 
    }); 

    return User; 

}); 
+0

最后发现这是因为模型没有从POST响应中正确更新id属性。不知道如何解决。 – 2012-07-27 22:07:37

+0

原来我没有收到来自服务器的正确数据。我的服务器对POST的响应是以字符串形式返回的id,而不是像{{id:“aaaa-bbb-ccc-ddd”}'这样的JSON对象。一旦解决了,一切正常。 – 2012-07-30 21:56:20

回答

0

问题原来是来自服务器的错误响应。一旦服务器发回正确的JSON对象,一切正常。