Подтвердить что ты не робот

JQuery перезаписать событие .click в пределах щелчка

У меня есть следующие функции:

TargetWorksheet.toggle_child_locations = function(id){
  $("#location-children-"+id).slideToggle("slow"); 
}

TargetWorksheet.get_child_locations = function(id, lvl){
  //Ajax grab all children and targets, and display children
  $.get('child_locations',{ location_id: id, level: lvl}, function(data){
    $("#location-children-"+id).append(data);
    TargetWorksheet.toggle_child_locations(id);
  });

  //Change onClick to just toggle since child data will now be loaded
  $("#location-toggle-"+id).click(function(){
    TargetWorksheet.toggle_child_locations(id);
  });
}

и этот вызов:

$(function(){
  TargetWorksheet.toggle_child_locations(2);
  $("#location-toggle-2").click(function(){
    TargetWorksheet.get_child_locations(2,1);
  });
});

Итак, я присоединяю событие click к моей ссылке "+" (# location-toggle-2), которая переключает дочерние данные. При первом щелчке я хочу сделать ajax-вызов для извлечения дочерних данных, но тогда я просто хочу перезаписать .click в # location-toggle-2, чтобы теперь он просто переключался и не вызывал вызов ajax, Вышеприведенный код не работает, он, похоже, не перезаписывает .click и каждый раз вызывает вызов ajax.

Кто-нибудь знает, как я могу перезаписать событие .click элемента? Я также пробовал $("#location-toggle-"+id).click(TargetWorksheet.toggle_child_locations(id)); И по какой-то причине он просто переделывал рекурсивно.

Мысли?

4b9b3361

Ответ 1

Единственное, что вам не хватает, заключается в том, что при использовании .click() каждый новый вызов добавляется новый обработчик, а не перезаписывается существующий.

Вы можете использовать $("#location-toggle-"+id). unbind(), чтобы очистить обработчики этого элемента перед добавлением нового, и он должен работать так, как вы ожидаете.