这是一个关于 Backbone.JS 和 ActiveRecord 的菜鸟问题。我将不胜感激有关如何调试它的指针。
我正在尝试使用 Backbone.Js 代码创建一个“Trainer”对象,该对象具有一个属性“name”(一个字符串)。该应用程序的前端是 Ruby on Rails。Trainer 表有一个数据迁移。
在培训师控制器中:
def create
document = Trainer.create! params[:trainer]
render :json => document
end
现在,在 app/assets/javascripts/backbone/views/trainers/new_view.js 中:
Gym.Views.Trainers.NewView = Backbone.View.extend({
el : 'div.trainer_form',
template: JST['backbone/templates/trainers/new_template'],
model : new window.Gym.Models.Trainer({}),
initialize: function() {
this.document = this.options.user;
Backbone.Validation.bind(this, {
invalid: function(view, attr, error) {
$("form#new-trainer .errors ul").append("<li>" + error + "</li>")
}
});
this.render();
},
render : function() {
$(this.el).html(this.template({trainer:this.model.toJSON()}));
return this
},
events : {
"click input#submit_button" : 'create_trainer'
},
create_trainer : function(event) {
event.preventDefault()
params = $("form#new-trainer").formParams()
params['user_id'] = Gym.currentUser.userId
this.model.save(params, {success : function(model, response) {
Gym.trainers.add(model)
Objects.views.selectTrainer.render()
Gym.current_trainer = model
$("select#trainer_selector").val(Gym.current_trainer.get('id'))
Objects.views.new_trainer.model = new Gym.Models.Trainer()
Objects.views.new_trainer.render()
}
});
现在,我可以在 Rails 日志中看到我正在访问控制器:
Started POST "/trainers" ...
Processing by TrainersController#create as JSON
Parameters: {"name"=>"Lori Stevens", "user_id"=>1, "trainer"=>{}}
但是,当它到达 SQL 时,我看到了:
[1m^[[36mSQL (0.4ms)^[[0m ^[[1mINSERT INTO `trainers` (`created_at`, `name`, `updated_at`, `user_id`) VALUES ('2012-11-07 20:33:09', NULL, '2012-11-07 20:33:09', NULL)^[[0m
参数“name”——来自模板,是 Trainer 对象的属性——没有进入数据库,即使在 JSON 中设置了参数“name”。
我很感激有关如何调试的指针 - 显然我不了解 Backbone.js 和 ActiveRecord 是如何连接的。