1

我有一个简单的 div,我动态地将按钮附加到,现在所有按钮单击事件都会触发,除了列表中的最后一个元素,有时它会触发,有时它不会触发。如果我单击按钮中的左侧或右侧图标,它工作得很好,如果我单击按钮的文本或中间,有时它会触发,有时它不会触发。

<div id="btn-list"></div>

在加载我的 dom 后的页面加载时,我附加了随机数量的按钮,并将 on click 事件侦听器添加到按钮。

$( function () {
  for (var i=0;i<arr.length;i++) {
    var item = arr[i];
    var btn = $(document.createElement('button'));
     btn.text(item['description']);
     btn.attr('id', i);
     $("#btn-list").append(btn);
  }

  $('#btn-list').on('click', 'button', function (e) {
    e.preventDefault();
    e.stopPropagation();
    window.location.replace('blah.html');
  });
}

我正在使用 jQuery 2.0。

4

1 回答 1

0

如果没有额外的代码,这个片段应该不会失败。请记住,对最后添加的按钮的引用保存在 中btn,因此如果在代码的其他部分修改元素或其事件,它将改变预期的行为。

您是否添加了一些调试输出以确认未触发单击事件?http://jsfiddle.net/AstDerek/gKJNe/

$('#btn-list').on('click', 'button', function (e) {
    e.preventDefault();
    e.stopPropagation();
    alert('blah.html');
})

添加了一个简单的测试,在我测试的浏览器上没有失败,也许它仅限于您的浏览器?http://jsfiddle.net/AstDerek/gKJNe/1/

现在,如果将按钮创建封装到它自己的函数中会发生什么?

function create_button (index,properties) {
    var btn = $(document.createElement('button'));

    btn.text(properties.description);
    btn.attr('id',index);
    $("#btn-list").append(btn);

    return btn;
}

for (var i=0;i<arr.length;i++) {
    create_button(i,arr[i]);
}

最后,作为一种解决方法,为什么不添加一个隐藏按钮作为最后一步呢?

for (var i=0;i<arr.length;i++) {
    create_button(i,arr[i]);
}

create_button(-1,{description:''}).hide();
于 2013-06-24T20:05:20.400 回答