さて、バックボーンビューとイベントが発生しないことに関する他のいくつかの質問を読みましたが、それでも悲しいことにそれを取得していません。私は約1日バックボーンをいじっていたので、基本的なものが欠けていると確信しています。これが私が取り組んでいるもののjsfiddleです:http: //jsfiddle.net/siyegen/e7sNN/3/
(function($) {
var GridView = Backbone.View.extend({
tagName: 'div',
className: 'grid-view',
initialize: function() {
_.bindAll(this, 'render', 'okay');
},
events: {
'click .grid-view': 'okay'
},
okay: function() {
alert('moo');
},
render: function() {
$(this.el).text('Some Cow');
return this;
}
});
var AppView = Backbone.View.extend({
el: $('body'),
initialize: function() {
_.bindAll(this, 'render', 'buildGrid');
this.render();
},
events: {
'click button#buildGrid': 'buildGrid'
},
render: function() {
$(this.el).append($('<div>').addClass('gridApp'));
$(this.el).append('<button id="buildGrid">Build</button>');
},
buildGrid: function() {
var gridView = new GridView();
this.$('.gridApp').html(gridView.render().el);
}
});
var appView = new AppView();
})(jQuery);
okay
GridViewのイベントは発生しません。これdiv.grid-view
は、イベントが最初にバインドされたときに存在しないためだと思います。ビューに動的に構築されたイベントのバインドと発生をどのように処理する必要がありますか?(また、これは短い例ですが、他にすべきでないことをしている場合は、遠慮なく私に怒鳴ってください)