2014-09-09 3 views
-1

Я создаю новое поле ввода с JQuery, которое включает кнопку удаления. Кнопка удаления работает на исходном элементе, но не работает на тех, которые были созданы с помощью JQuery.Удалить элемент при нажатии с помощью JQuery

документ после того, как два новых поля электронной почты добавил

<fieldset> 
       <legend>Send Email</legend> 
       <label>Emails(s) to send notice to.</label> 
       <p> 
        <input type="email" name="emails[]" style="cursor: auto; background-image: url(); background-attachment: scroll; background-position: 100% 50%; background-repeat: no-repeat;"><span class="btn_orange"><a href="#" class="remove_field">x</a></span> 
       </p> 
       <p><input type="email" name="emails[]"><span class="btn_orange"><a href="#" class="remove_field">x</a></span></p><p><input type="email" name="emails[]"><span class="btn_orange"><a href="#" class="remove_field">x</a></span></p><p> 
        <span class="btn_orange"><a class="add_email_button" href="#">Add Another Email</a></span> 
       </p> 
       <p> 
        <span class="btn_orange"><a class="ui-button">Send Email</a></span> 
       </p> 
      </fieldset> 

Script

<script type="text/javascript"> 
    $(document).ready(
     function() { 
      $("#importbutton").click(function() { 
       $("#ProgressBarImg").show(); 
       $.get('@Url.Action("Import", "Import")', {}, 
       function (data) { 
        $('body').html(data); 
        $('#ProgressBarImg').hide(); 
       }); 
       $("#importbutton").removeAttr("href"); 
      } 
      ); 

      var dialog = $("#emailSection").dialog({ 
       autoOpen: false, 
       height: 400, 
       width: 475, 
       modal: true 
      }); 

      $('#emailButton').click(function() { 
       $(dialog).dialog("open"); 
       $('#emailButton').removeAttr('href'); 
      }); 
      $('.add_email_button').closest('p').click(function() { 
       var html = '<p><input type="email" name="emails[]" /><span class="btn_orange"><a href="#" class="remove_field">x</a></span></p>'; 
       $(html).insertBefore($(this)); 
      }); 

      $('a.remove_field').closest('p').click(function() { 
       $(this).remove(); 
      }); 
     } 
    ); 
</script> 
+3

Используйте 'on' для присоединения событий - он использует делегирование событий. Раньше это называлось «live». Итак, '$ ('. MySelector'). On ('click', function() {});' –

+0

@Chris. Что вы не используете делегирование событий, вам нужно использовать '$ (document) .on ('event', delegateSelector) 'Однако в этом случае нет селектора, чтобы получить' p' над 'a.remove_field', поэтому вы не могли бы это использовать, если только вы не добавили класс в p, который OP добавляет обработчик кликов к –

+0

@JuanMendes Все верно. Мой комментарий не был полностью точным; однако он просто предназначен для указания ОП в правильном направлении. Слишком поздно, чтобы редактировать сейчас, но вопрос о дублике имеет ответ с подробностями, как и документы. –

ответ

1

Вы Установка событие на элементе, который на первой странице. После того, как вы добавите новые элементы, новые элементы не имеют обработчика, вы можете добавить его, если вы добавите его, но это лучший способ.

Используйте событие делегации: http://jsfiddle.net/mendesjuan/4my1dhw1/

$(document).on('click', 'a.remove_field', function() { 
    $(this).closest('p').remove(); 
}); 

Это означает, что вы слушаете за клики по всему документу, но фильтрование только те, которые вам интересны

Второе преимущество заключается в том, что вам. не требуется отдельный обработчик для каждого элемента, сохраняя вашу память.

Код, который я разместил, отличается по своему поведению от того, что у вас было, для чего требуется, чтобы вы нажмете x. Ваш код будет удаляться, когда вы нажимаете в любом месте в <p>. Причина, по которой я изменил ее, заключается в том, что нет селектора CSS, который имитирует то, что делает closest('p'), то есть селектор CSS не поднимается по дереву. Однако у меня, кажется, больше смысла, и вы, вероятно, были using closest('p') только потому, что хотите удалить весь <p>, но вы можете сделать это изнутри обработчика.

0

Для элементов, которые были добавлены после загрузки страницы, вы должны использовать:

$('body').on('click', '.classSelector', function(e) { 

}); 
+0

Ха-ха должно быть прямо сейчас – Tim

+0

Это работает благодаря –

Смежные вопросы