本文實例講述了JavaScript實現動態添加、移除元素或屬性的方法。分享給你們供你們參考,具體以下:javascript
JavaScript 動態添加、移除元素css
appendChild(newnode)
向節點的子節點列表的末尾添加新的子節點。html
insertBefore(newnode, existingnode)
在已有子節點以前插入新的子節點。前端
removeChild(node)
刪除元素的某個指定的子節點,並以 Node 對象返回被刪除的節點,若是節點不存在則返回 null。java
innerHTML
屬性設置或返回表格行的開始和結束標籤之間的 HTML。node
測試用例app
<html> <head> <style type="text/css"> .style1 { background-color:yellow; width:200px;height:100px;float:left;} .style2 { background-color:#aa0; width:200px;height:100px;float:left;} .style3 { background-color:rgb(0,200,200); width:200px;height:100px;float:left;} .item-style {background-color:pink;} </style> <script type="text/javascript"> function addElement1() { var container = document.getElementById("container1"); var elem1 = document.createElement("div"); elem1.setAttribute("class", "item-style"); var textnode1 = document.createTextNode("appendChild"); elem1.appendChild(textnode1); container.appendChild(elem1); var middleChild = document.getElementById("middle-child"); var elem2 = document.createElement("div"); elem2.setAttribute("class", "item-style"); var textnode2 = document.createTextNode("insertBefore"); elem2.appendChild(textnode2); container.insertBefore(elem2, middleChild); }//歡迎加入全棧開發交流圈一塊兒學習交流:582735936 ]//面向1-3年前端人員 } //幫助突破技術瓶頸,提高思惟能力 function addElement2() { var container = document.getElementById("container2"); container.innerHTML = "<div>Hello World \"2\"</div>"; } function removeNode() { var container = document.getElementById("container3"); var myNode = document.getElementById("myNode"); container.removeChild(myNode); } function operateElements() { addElement1(); addElement2(); removeNode(); } </script> </head> <body onload="operateElements()"> <div id="container1" class="style1"> <div id="middle-child">Middle Child</div> </div> <div id="container2" class="style2"></div> <div id="container3" class="style3"><p id="myNode">Hello World</p></div> <div style="clear:both;"/> <button onclick="operateElements()">Operate Elements</button> </body> </html>
JavaScript 動態添加、移除屬性學習
setAttribute(attributename, attributevalue)
添加指定的屬性,併爲其賦指定的值。將屬性設置爲undefined等同於刪除。測試
removeAttribute(attributename)
刪除指定的屬性。ui
getAttributeNode(attributename)
以 Attr 對象返回指定屬性名的屬性值。
removeAttributeNode(attributenode)
刪除 Attr 形式指定的屬性,同時返回被刪除的Attr 形式的屬性。
測試用例
<html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <script type="text/javascript"> function operateAttributes() { var node2 = document.getElementById("node2"); //設置font-style和font-size無效,這些屬性脫離style單獨設置是無效的 node2.setAttribute("style", "color:red;"); var node3 = document.getElementById("node3"); node3.setAttribute("font-size", undefined); var node4 = document.getElementById("node4"); //font-style和font-size的remove無效,由於它們沒有單獨存在 node4.removeAttribute("font-size"); var node5 = document.getElementById("node5"); //沒法獲取font-style和font-size var attributeNode = node5.getAttributeNode("style"); var attr = node5.removeAttributeNode(attributeNode); node5.innerHTML = "attr=" + attr + ", attr.name=" + attr.name + ", attr.value=" + attr.value; } </script> </head> <body onload="operateAttributes()"> <p id="node0" style="font-style:italic;font-size:12px;">0 Hello World</p> <p id="node1" font-size="12px" font-style="italic">1 Hello World : font-size、font-style等,這些屬性脫離style單獨設置是無效的</p> <p id="node2" style="font-style:italic;font-size:12px;">2 Hello World setAttribute</p> <p id="node3" style="font-style:italic;font-size:12px;">3 Hello World setAttribute</p> <p id="node4" style="font-style:italic;font-size:12px;">4 Hello World removeAttribute</p> <p id="node5" style="font-style:italic;font-size:12px;">5 Hello World getAttributeNode & removeAttributeNode</p> </body> </html>