将集合绑定到Backbone中的模型

时间:2012-07-20 07:24:41

标签: javascript asp.net-mvc-3 backbone.js client-side backbone-events

我有一个服务器端类:TopicsListModel 具有如下属性:

public class TopicsListModel
{
    public TopicsListModel()
    {
        ChildTopics = new HashSet<TopicsListModel>();
    }

    public int Id { get; set; }
    public string Name { get; set; }
    public ICollection<TopicsListModel> ChildTopics { get; set; }
}

有一个返回List的函数,

public JsonResult SearchTopic(String topic)
    {
        var topics = LandingManager.SearchTopics(topic);
        //return Json(topics);
        return new JsonResult { Data = topic, JsonRequestBehavior = JsonRequestBehavior.AllowGet };
    }

我需要将它添加到Backbone模型和集合中。我是Backbone的新手,我正在努力,你可以猜到。任何帮助将不胜感激。

我想构建一个存储数据的模型,如:

{    name: "Model1",    id: 1,    submodels: [{ name: "Submodel1", id: 2 }, { name: "Submodel1", id: 2 }] } 

我无法这样做,我无法设置像这样的基本集合,ASP.NET MVC代码部分返回我共享的数据。分享我在Backbone中所做的一切:

TestBB = function () {
if (!window.console) window.console = { log: function () { } };

var treeModel = Backbone.Model.extend({});
var treeSubModel = Backbone.Model.extend({});
var treeCollection = Backbone.Collection.extend({
    model: treeSubModel,
    initialize: function () {
        console.log('Collection Initialized');
    }
});
var treeView = Backbone.View.extend({
    el: $('#tree-view'),
    initialize: function () {
        //            this.collection.bind("render", this.render, this);
        //            this.collection.bind("addAll", this.addAll, this);
        //            this.collection.bind("addOne", this.addOne, this);
        _.bindAll(this);
    },
    render: function () {
        console.log("render");
        console.log(this.collection.length);
        $(this.el).html(this.template());
        this.addAll();
        var template = _.template($("#template").html(), {});
        this.el.html(template);
    },
    addAll: function () {
        console.log("addAll");
        this.collection.each(this.addOne);
    },
    addOne: function (model) {
        console.log("addOne");
        view = new treeView({ model: model });
        $("ul", this.el).append(view.render());
    },
    events: { "click #btnFind": "doFind" },
    doFind: function (event) { alert('event fired'); }
});

return {
    TreeView: treeView
};} (Backbone);

请建议。

2 个答案:

答案 0 :(得分:0)

这不是将集合“绑定”到后端的情况,因此:您fetch要从服务器读取集合,并save(通过同步)写入

首先,您需要通过设置url属性让集合知道数据所在的位置。请参阅:http://backbonejs.org/#Collection-url

其次,您需要使用fetch方法实际检索数据。见http://backbonejs.org/#Collection-fetch。请注意,这是异步的,因此您需要等待success回调。

要保存数据,请在各个型号上使用save方法。请参阅http://backbonejs.org/#Model-save

答案 1 :(得分:-3)

解决 我找出了方法并定义了模型并填充了它!