在将模型发送到数据库之前,是否有更好的方法使用表单中的值更新模型?我想做这样的事情:
mySave: function () {
this.model.save($(this.el).find(':input').serializeArray());
},
问题是.serializeArray()
返回一个数组[{key1:"val1"}, {key2:"val2"}]
,而backbone.js model.save()
期待一个对象{"key1":"val1", "key2":"val2"}
作为参数。
后端是asp.net MVC。我提到这一点,以防万一有更好的方法将这些信息传回服务器。
目前,我只是遍历序列化数组并逐个设置Backbone Model上的每个属性。
答案 0 :(得分:2)
我只是写了这个:https://github.com/macek/jquery-to-json
查看在此工作的演示http://macek.github.com/jquery-to-json
(function($){
$.fn.toJSON = function(options){
options = $.extend({}, options);
var self = this,
json = {},
push_counters = {},
patterns = {
"validate": /^[a-zA-Z][a-zA-Z0-9_]*(?:\[(?:\d*|[a-zA-Z0-9_]+)\])*$/,
"key": /[a-zA-Z0-9_]+|(?=\[\])/g,
"push": /^$/,
"fixed": /^\d+$/,
"named": /^[a-zA-Z0-9_]+$/
};
this.build = function(base, key, value){
base[key] = value;
return base;
};
this.push_counter = function(key, i){
if(push_counters[key] === undefined){
push_counters[key] = 0;
}
if(i === undefined){
return push_counters[key]++;
}
else if(i !== undefined && i > push_counters[key]){
return push_counters[key] = ++i;
}
};
$.each($(this).serializeArray(), function(){
// skip invalid keys
if(!patterns.validate.test(this.name)){
return;
}
var k,
keys = this.name.match(patterns.key),
merge = this.value,
reverse_key = this.name;
while((k = keys.pop()) !== undefined){
// adjust reverse_key
reverse_key = reverse_key.replace(new RegExp("\\[" + k + "\\]$"), '');
// push
if(k.match(patterns.push)){
merge = self.build([], self.push_counter(reverse_key), merge);
}
// fixed
else if(k.match(patterns.fixed)){
self.push_counter(reverse_key, k);
merge = self.build([], k, merge);
}
// named
else if(k.match(patterns.named)){
merge = self.build({}, k, merge);
}
}
json = $.extend(true, json, merge);
});
return json;
};
})(jQuery);
答案 1 :(得分:1)
它不是默认的javascript,但是Derick Bailey确实为骨干创建了一个模型绑定插件, 这使您的模型/视图保持同步 如果更新文本字段,它将更新您的模型属性 如果更改了模型属性,它将更新视图
这里有更多信息: https://github.com/derickbailey/backbone.modelbinding
现在您无需在保存中传递任何内容,您的模型是最新的,只需调用
即可model.save();
答案 2 :(得分:0)
如果你的源是一个对象数组,你可以使用json2(现在大多数现代浏览器都是固有的):
var coll = $(this.el).find(':input');
JSON.stringify(coll);
来自json2.js:
text = JSON.stringify(['e', {pluribus: 'unum'}]); // text = '["e",{"pluribus":"unum"}]'