js动态创建按钮并绑定事件的问题

需要拿js来渲染一个列表,组件比较多因此采取document.createElement的方式动态创建元素

let b1 = document.createElement('button')
b1.onclick=add(i)

但是这样在渲染的时候就会默认执行add方法,我希望的是点击这个按钮才执行,有人有办法吗

阅读 3.8k
3 个回答

b1.addEventListener('click', add);

你这是受vue影响了吧,onclick=add(i)就是执行add,下面的给你几个参考

function test(...a){console.log(this, ...a)}
btn.onclick = test.bind(btn, i)
btn.onclick = function(e){test.call(this, e, 5)}
btn.addEventListener('click', test.bind(btn, 9))

b1.onclick = this.add.bind(this,i)

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题