如果我点击第一个“编辑”我得到一个console.log('click happend')
但如果我通过JavaScript添加这些框中的一个(点击“添加框”),然后编辑click
从这新箱子不起作用。我知道这是因为javascript在元素不存在的情况下运行,这就是为什么没有click事件监听器的原因。我也知道用jQuery我能做到像这样:添加点击事件到元素插入javascript
$('body').on('click', '.edit', function(){ // do whatever };
而且是可行的。
但是我怎样才能用纯Javascript来做到这一点?我找不到任何有用的资源。创建了一个我想要工作的简单例子。解决这个问题的最好方法是什么?
所以问题是:如果你添加一个框,然后点击“编辑”,什么都不会发生。
var XXX = {};
XXX.ClickMe = function(element){
this.element = element;
onClick = function() {
console.log('click happend');
};
this.element.addEventListener('click', onClick.bind(this));
};
[...document.querySelectorAll('.edit')].forEach(
function (element, index) {
new XXX.ClickMe(element);
}
);
XXX.PrototypeTemplate = function(element) {
this.element = element;
var tmpl = this.element.getAttribute('data-prototype');
addBox = function() {
this.element.insertAdjacentHTML('beforebegin', tmpl);
};
this.element.addEventListener('click', addBox.bind(this));
};
[...document.querySelectorAll('[data-prototype]')].forEach(
function (element, index) {
new XXX.PrototypeTemplate(element);
}
);
[data-prototype] {
cursor: pointer;
}
<div class="box"><a class="edit" href="#">Edit</a></div>
<span data-prototype="<div class="box"><a class="edit" href="#">Edit</a></div>">Add box</span>
This Q/A is useful information但它不回答我有关如何解决这个问题的问题。就像我如何为那些动态插入DOM的元素调用eventListener(s),如new XXX.ClickMe(element);
?
的可能的复制[什么是DOM事件代表团?](https://stackoverflow.com/questions/1687296/what-is-dom-event-delegation ) –