Search code examples
javascriptappendremovechild

limit/stop removeChild when the task is done


I'm using removeChild to delete an appendChild image, removeChild is triggered by an onclick event.

Elaboration:

USER clicks a button and appends an image next...

Code:

var src = "img2/" + selected + ".jpg";
      var img = document.createElement("img");
      img.src = src;
      img.id = 'someImage';

     if ($('#someImage').length === 0){ 
            holder.appendChild(img);
      img.style.display = "inline";
            display =  true;
            console.log(display);
            console.log(country);
            console.log(selected);

User Clicks Remove Button to remove the append Image

Code:

selected =  document.getElementById("country").value;
  display = false;
  document.getElementById("country").value = "";
  selected = null;    
  var Myholder = document.getElementById("holder");
  Myholder.removeChild(Myholder.childNodes[0]);

The code works properly however while cleaning up my code I saw an error in the console that says "TypeError: Argument 1 of Node.removeChild is not an object." meaning the removeChild function is still working even if the appendChild is already removed. How can I limit/stop it when there is nothing to remove?(all the functions are triggered once the user clicks the button meaning when the user clicks the remove button when there is nothing to remove the error shows)


Solution

  • just check if the parent node has child nodes. if yes, invoke the action. else not

    var Myholder = document.getElementById("holder");
    if(Myholder.hasChildNodes()) {
        Myholder.removeChild(Myholder.childNodes[0]);
    }
    

    documentation : Node.hasChildNodes()