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

我正在尝试学习backbone.js,我无法理解如何绑定模型并在获取后读取它们.
这是我的代码
$(function() {
    var Bid = Backbone.Model.extend();

    var BidsList = Backbone.Collection.extend({
        model: Bid,url: '/buyers/auction/latestBids?auctionId=26&latestBidId=0',});         

    var BidsView = Backbone.View.extend({
        el: $('#bids'),initialize: function() {
            log('hi');
            _.bindAll(this,'render');

            this.collection = new BidsList();                   

            this.collection.fetch();
            this.render();
        },render: function() {                    
            log(this.collection);

            return this;
        },});

    var bidsView = new BidsView();

});

function log(m) { console.log(m); }

这就是webservice json的样子

{
    "AuctionState":3,"ClosedOn":null,"Bids":[
        {
            "BidId":132,"AuctionId":26      
        },{
            "BidId":131,"AuctionId":2           
        }
    ]
}

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

解决方法

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

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

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

例如:

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

相关文章

JS原生Ajax操作(XMLHttpRequest) GET请求 POST请求 兼容性问题 利用iframe模拟ajax 实现表单提交的返回...
AJAX 每日更新前端基础,如果觉得不错,点个star吧 😃 https://github.com/WindrunnerMax/E...
踩坑Axios提交form表单几种格式 前后端分离的开发前后端, 前端使用的vue,后端的安全模块使用的SpringSe...
很早就听闻ajax的名声,但是却一直不知道怎么用,今天自己捣鼓了一下,竟然会用了,哈哈哈哈。 为了防止...
需要在服务器上进行哈 jquery的ajax方法: // jquery请求 $.ajax({ url: "./server/slider.js...
Ajax函数封装ajax.js // Get / Post // 参数 get post // 是否异步 // 如何处理响应数据 // URL // var...