jQuery单击不触发异步添加的元素

时间:2013-04-01 01:18:09

标签: jquery asynchronous append

我已经看到了应该回答我的其他问题,但出于某种原因,他们没有。我指的是这些:
- jquery click event not firing?
- jquery functions dont work on dom elements loaded asynchromously

我首先使用click()尝试将所选“li”的颜色更改为粉红色。它有效,但不适用于动态附加的“li”。我尝试使用on(),因为live()现已弃用。 我很惊讶它仍然没有用。

这是您可以运行的示例:

使用Javascript:

<script src="//ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js">
</script>

<script>
$(document).ready(function(){
  $("#btn1").click(function(){
    $("ol").append("<li class='test'> Appended item </li>");
  });
});
</script>

<script>
$(function () {
  $('.test').on('click', function () {
    $(this).css("background-color","pink");
  });
});
</script>

HTML:

<body>
  <p>This is a paragraph.</p>
  <p>This is another paragraph.</p>
  <ol>
    <li class='test'> List item 1 </li>
    <li class='test'> List item 2 </li>
    <li class='test'> List item 3 </li>
  </ol>

  <button id="btn1">Append list item</button>
</body>

有没有人有线索? 非常感谢!

1 个答案:

答案 0 :(得分:12)

您需要根据delegation

使用事件.on()
$('ol').on('click', '.test', function(el){
    $(this).css("background-color","pink");
})

演示:Fiddle