使用ajax获取后,Backbone.js将集合绑定到模型

前端之家收集整理的这篇文章主要介绍了使用ajax获取后,Backbone.js将集合绑定到模型前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在尝试学习backbone.js,我无法理解如何绑定模型并在获取后读取它们.
这是我的代码
  1. $(function() {
  2. var Bid = Backbone.Model.extend();
  3.  
  4. var BidsList = Backbone.Collection.extend({
  5. model: Bid,url: '/buyers/auction/latestBids?auctionId=26&latestBidId=0',});
  6.  
  7. var BidsView = Backbone.View.extend({
  8. el: $('#bids'),initialize: function() {
  9. log('hi');
  10. _.bindAll(this,'render');
  11.  
  12. this.collection = new BidsList();
  13.  
  14. this.collection.fetch();
  15. this.render();
  16. },render: function() {
  17. log(this.collection);
  18.  
  19. return this;
  20. },});
  21.  
  22. var bidsView = new BidsView();
  23.  
  24. });
  25.  
  26. function log(m) { console.log(m); }

这就是webservice json的样子

  1. {
  2. "AuctionState":3,"ClosedOn":null,"Bids":[
  3. {
  4. "BidId":132,"AuctionId":26
  5. },{
  6. "BidId":131,"AuctionId":2
  7. }
  8. ]
  9. }

我如何将该响应绑定到模型?

解决方法

您需要覆盖BidC​​ollection上的parse()方法以将Bids拉出并将它们(仅限它们)呈现给集合的add()例程.您可以使用parse()方法执行其他操作来管理AuctionState字段.

您还需要在视图中侦听“更改”事件,以便在获取后视图自动更新.您不需要在视图中调用render();你应该将模型的’change’事件绑定到render(),然后获取数据并让它触发渲染.

与往常一样,Backbone的源代码具有高可读性.我建议学习和理解它.

例如:

  1. var BidsList = Backbone.Collection.extend({
  2. model: Bid,parse: function(response){
  3. return response.Bids;
  4. }
  5. });

猜你在找的Ajax相关文章