Welcome to ShenZhenJia Knowledge Sharing Community for programmer and developer-Open, Learning and Share
menu search
person
Welcome To Ask or Share your Answers For Others

Categories

When a button is clicked, I want to add an element to my DOM. But first, I want to remove the previous one I added (in the previos click). Inside the click handler I wrote:

document.getElementById("myId").remove();
var myP = document.createElement("p");
myP.setAttribute("id","myId");
myP.innerHTML = "asdf";
document.getElementById("myDiv").appendChild(myP); 

but it's not working, the "p" does not get added to the DOM.

note: I want to use only javaScript, and I want to use "remove()" and not innerHTML = "".


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
thumb_up_alt 0 like thumb_down_alt 0 dislike
4.4k views
Welcome To Ask or Share your Answers For Others

1 Answer

I have tried your code and it works fine. Just create a new HTML file and use the following code, in order to test it. Maybe you are missing an id in the javascript code.

<!DOCTYPE html>
<html>
    <head>
        <script>
            function clickTest(){
                document.getElementById("myId").remove();
                var myP = document.createElement("p");
                myP.setAttribute("id","myId");
                myP.innerHTML = "asdf";
                document.getElementById("myDiv").appendChild(myP);
            }
        </script>
    </head>
    <body>
        <div id="myId" style="border:1px solid black;">
            TEST
        </div>
        <div id="myDiv" style="border:1px solid red;">
            TEST2
        </div>
        <br/>
        <button onclick="clickTest();">CLICK ME</button>
        
    </body>
</html>

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
thumb_up_alt 0 like thumb_down_alt 0 dislike
Welcome to ShenZhenJia Knowledge Sharing Community for programmer and developer-Open, Learning and Share
...