У меня есть мнение, что каждый раз, когда вызывается повторно визуализирует элементы в представлении, вот кусок кода, в:JQuery DOM событие не работает на Backbone View
Project.Views.CheckinScheduledView = Backbone.View.extend({
tagName: 'div',
id:'CheckinScheduledView',
className:'section',
checkinsHtml: '',
initialize: function() {
_.bindAll(this);
this.checkinsCollections = new Project.Collections.Checkins();
this.checkinsCollections.on('reset', this.render);
this.checkinsCollections.fetch();
},
events: {
'click .scheduled_checkin a':'deleteCheckin'
},
render: function() {
var that = this;
// HERE IS THE PROBLEM
if($('li.scheduled_checkin').length) {
$('li.scheduled_checkin').each(function() {
$(this).css('display','none').empty().remove();
});
}
if(Project.InfoWindow.length) {
Project.InfoWindow[0].close();
}
_.each(this.checkinsCollections.models, function(item) {
that.renderLocation(item);
});
$(this.el).html(this.template());
this.renderCheckins();
return this;
},
refreshData: function() {
this.checkinsCollections.fetch();
}
это случай:
- открыта страница
- нажмите на CheckIN (текущий код вида)
- вернуться домой
- вида визуализации, но добавляет ITE мс в списке
изображения
Первый раз я загрузить вид
давайте говорить, что я иду к другой точке зрения, и теперь я вернусь к этой точке зрения
и снова: (
Вы можете добавить jsfiddle/jsbin? – alonisser
Btw, вероятно, '$ ('li.scheduled_checkin'). Remove()' будет работать, так как он имеет неявную итерацию, как в [здесь] (http://api.jquery.com/each/) – alonisser
@alonisser i попробовал это и не сработает, вот jsfiddle http://jsfiddle.net/rommelxcastro/Pnwp8/ –