backbone.js模型和收集开销
当我从服务器获取模型或集合时,我无法访问模型的属性,除非我进行字符串化然后重新解析。假设模型本身有一些来自backbone.js的额外开销?请注意,在下面的代码中,我可以按顺序执行stringify/parse,这应该会得到与我开始时相同的结果。然而,很明显,我已经通过执行这两个步骤消除了一些多余的信息,因为我的模型的属性现在与以前不同。当然,我不需要通过这两个步骤来访问我的模型属性,对吗backbone.js模型和收集开销,backbone.js,backbone.js-collections,Backbone.js,Backbone.js Collections,当我从服务器获取模型或集合时,我无法访问模型的属性,除非我进行字符串化然后重新解析。假设模型本身有一些来自backbone.js的额外开销?请注意,在下面的代码中,我可以按顺序执行stringify/parse,这应该会得到与我开始时相同的结果。然而,很明显,我已经通过执行这两个步骤消除了一些多余的信息,因为我的模型的属性现在与以前不同。当然,我不需要通过这两个步骤来访问我的模型属性,对吗 Eg. thismodel = /// assume this came from server fe
Eg.
thismodel = /// assume this came from server fetch
alert(thismodel.name); // DOES NOT WORK - undefined
jsonmodel = JSON.stringify(thismodel);
var providerprefslistJSON = jQuery.parseJSON(jsonmodel);
alert(providerprefslistJSON.name); // WORKS
首先,您是否正在尝试访问模型或响应的属性 从
alert(thismodel.name)
可以看出,您要的是模型的属性,而不是属性。如果您正在查找model属性,那么可能需要alert(this.model.get('name'))
如果您确实选择model.name,那么基本上问题可能在于如何解析数据。例如,假设来自服务器的JSON如下{'name':'Jimmy'}
当原始JSON发送的model.response
在object.name下有“Jimmy”名称空间时,主干将自动将其转换为模型属性,除非另有指示(例如modelObj.attributes.name),此时您将使用get()
函数
如果一切正常,您应该能够相当简单地访问模型数据
例如取回
var model = new MyModel();
model.id = 1;
model.fetch({
success: function(model, response) {
console.log(model.get('name')); // The model name attribute
console.log(response.name); // The RAW response name property
}
});
或者您的服务器没有将数据作为JSON数据发送回。服务器响应是否为content type=“application/json”
有些东西需要检查。主干模型对象不是普通的老JavaScript对象。他们保留自己的属性。要访问
name
属性,可以执行以下操作之一:
警报(thismodel.attributes.name)代码>
或者更好地使用:
alert(thismodel.get(“name”)代码>
当您将模型转换为JSON然后再转换回来时,它工作的原因是因为JSON.stringify
调用,它从内部属性散列创建一个JSON字符串,这意味着当您解析该字符串时,您会得到一个普通的旧JavaScript对象,它与主干模型对象不同