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?