mój kod:błąd backbone.js - Uncaught TypeError: Object [object Object] ma metodę 'Ustaw'
Jestem nowy backbone.js i stara się zbudować aplikację z backbone.js i PHP. Kiedy próbuję zadzwonić add
w routerze, otrzymuję błąd:
Uncaught TypeError: Object [object Object] has no method 'set'.
Proszę pomóc mi znaleźć mój błąd.
Dzięki.
// Models
window.Users = Backbone.Model.extend({
urlRoot:"./bb-api/users",
defaults:{
"id":null,
"name":"",
"email":"",
"designation":""
}
});
window.UsersCollection = Backbone.Collection.extend({
model:Users,
url:"./bb-api/users"
});
// Views
window.AddUserView = Backbone.View.extend({
template:_.template($('#new-user-tpl').html()),
initialize:function(){
this.model.bind("click", this.render, this);
},
render:function(){
$(this.el).html(this.template(this.model.toJSON()));
return this;
},
events:{
"click .add":"saveUser"
},
saveUser:function(){ alert('saveUser');
this.model.set({
name:$("#name").val(),
email:$("#email").val(),
designation:$("#designation").val()
});
if(this.model.isNew()){
this.model.create(this.model);
}
return false;
}
});
// Router
var AppRouter = Backbone.Router.extend({
routes:{
"":"welcome",
"users":"list",
"users/:id":"userDetails",
"add":"addUser"
},
addUser:function(){
this.addUserModel = new UsersCollection();
this.addUserView = new AddUserView({model:this.addUserModel});
$('#content').html(this.addUserView.render().el);
}
});
var app = new AppRouter();
Backbone.history.start();
Twój przechodzącą kolekcji do widoku, a następnie stara się traktować je jako instancja modelu. To nie jest. To jest kolekcja. – asawyer
Aby wyjaśnić: 'Backbone.Collection' nie ma metody' set'. – jakee
Dzięki za pomoc – Nag