我行的数量:取得按钮单击事件处理火灾不止一次
var goal_index = 2;
而且我有一个函数,它创建一些行(默认值2行),有两个按钮:垃圾桶(删除行),添加(添加anoter行)。
// Creating Goals
var goals_creating = function(){
var goals_area = $('.goalsArea'),
add_button = $('<span class="add_btn"></span>'),
trash_button = $('<span class="trash_btn"></span>');
goals_area.html('');
for(var i = 0, j = 1; i < goal_index; i++, j++){
goals_area.append(
'<div class="row" data-trashgoal = ' + i + '>' +
'<div class="col-lg-1">' +
'<span class="trash_btn" data-trashgoal = ' + i + '></span>' +
'</div>' +
'</div>'
);
}
// Last trash tag
var last_trash_btn = $('.trash_btn').last();
// Insert after last trash button
last_trash_btn.after(add_button);
};
在功能的最后部分,我插入按钮(添加)到最后一行。 这运行我的功能后:
goals_creating();
运行后,我创建了两个事件两个按钮(添加)和(删除):
$('.add_btn').on('click', function(){
goal_index++;
goals_creating();
});
$('.trash_btn').on('click', function(){
var goal_to_del = $(this).data('trashgoal');
$('.row[data-trashgoal="' + goal_to_del + '"]').remove();
goal_index--;
goals_creating();
});
但是,他们的工作有一段时间,之后按钮保持非活动状态,不起作用。 我该如何解决这个错误?谢谢
它只能工作一次,因为您创建了一个新的按钮,当添加事件处理程序时它不在那里。改用委托事件处理程序。 – adeneo 2014-11-08 14:16:56