The following solution adds an event listener to the dynamically created <div>
element with the class style .duck
applied.
let body = document.getElementsByTagName("body")[0];
let button = document.getElementById('create');
let ducks = document.querySelectorAll("duck");
let counter = 0;
/* This function is used to create a new item. */
function createDuck() {
let newDuck = document.createElement("div");
newDuck.innerHTML = counter++;
newDuck.classList.add("duck");
body.appendChild(newDuck);
return newDuck;
};
/* This method checks if the element applies a class style. */
function hasClass(elem, className) {
return elem.className.split(' ').indexOf(className) > -1;
}
/* This event listener triggers new item creation. */
button.addEventListener('click', function() {
createDuck();
});
/* The following item adds an event listener to the dynamically created item. */
document.addEventListener('click', function (e) {
if(hasClass(e.target, 'duck')) {
e.target.classList.add('shot');
}
}, false);
.duck {
color: red;
border: 1px solid blue;
margin-top: 10px;
cursor: pointer;
}
.shot {
background-color: yellow;
}
<body>
<button id="create">Create</button>
</body>
1 - Event binding on dynamically created elements?