J'essaie d'apprendre les vues imbriquées avec Backbone.js et j'ai rencontré un problème. Aucune erreur n'est levée cependant, il n'affiche aucune sortie ou donnée. Toute aide serait très appréciée. V/R ChrisBackbone.js vue imbriquée ne pas rendre les données
lienà jsFiddle: http://jsfiddle.net/cpeele00/PcmMW/8/
var User = Backbone.Model.extend({});
var Users = Backbone.Collection.extend({
model: User
});
var UserItemView = Backbone.View.extend({
tagName: 'li',
template: _.template($('#user-list-template').html()),
render: function() {
this.$el.html(this.model.toJSON());
return this;
}
});
var UserListView = Backbone.View.extend({
render: function() {
this.$el.empty();
var self = this;
this.collection.each(function(model) {
self.renderItem(model);
});
},
renderItem: function(item) {
var itemView = new UserItemView({
model: item
});
this.$el.append(itemView.render().el);
}
});
var user1 = new User();
user1.set({
firstname: 'momo',
lastname: 'peele'
});
var user2 = new User();
user2.set({
firstname: 'bobo',
lastname: 'peele'
});
var users = new Users([user1, user2]);
var listView = new UserListView({
collection: users
});
listView.render();
Voici le balisage HTML et modèle
<div id="user-list">
<fieldset>
<legend>Users</legend>
<ul></uL>
</fieldset>
</div>
<script id="user-list-template" type="text/template">
<%= firstname %>
<%= lastname %>
</script>
Merci! Oui, j'utilise le débogueur Chrome pour les applications que j'écris mais il ne m'est pas venu à l'esprit de l'utiliser avec jsFiddle. Merci encore et prenez soin de vous! – cpeele00