jumpToWave事件只被触发一次,我不明白为什么。
这是我的观点:
var WaveModalView = Backbone.View.extend({
template:_.template($('#tpl-wave-modal').html()),
events: {
'hidden': 'remove',
'click .jumpToWaveBtn':'jumpToWave'
},
jumpToWave:function(e){
e.preventDefault();
console.log("JMP")
var marker = this.model.collection.markers[this.model.id];
map.panTo(marker.getPosition());
bounceMarker(marker,1750);
},
render:function () {
var model = this.model;
var that = this;
$(this.el).html(this.template(model.toJSON()));
if(model.get('waveReviews').length > 0){
var reviewList = new WaveReviewList({model: model});
$('#waveReviews' + model.id).html(reviewList.render().el);
}
this.$("#waveSync" + model.id).click(function(e){
e.preventDefault();
if(window.me){
requestSyncWave(model.id,function(data){
window.me.fetch();
});
}
});
this.$("#waveEdit" + model.id).click(function(e){
e.preventDefault();
window.waveUnderEdit = model;
$(that.el).children(":first").modal('hide');
openWaveEditModal(model);
});
return this;
}
});
这是模板中的相关按钮:
<button class="btn btn-info jumpToWaveBtn" data-dismiss="modal" aria-hidden="true">Auf Karte
anzeigen</button>
我点击按钮时有多个模态。在“JMP”不再被记录之后,该事件仅针对每个模态触发一次。
答案 0 :(得分:3)
我没有在render
上看到您的代码正在调用WaveModalView
,但我怀疑问题是您是从其他地方拨打render()
,而后者则调用$(this.el).html(...)
{1}},它取代了视图元素的内容,新插入的内容没有绑定到其元素的事件。
如果这确实是问题,您可以通过在this.delegateEvents()
函数末尾添加render()
来解决此问题。
例如,请检查此问题和答案:Why are events not firing after the second render in Backbone.js?