欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript創(chuàng)建元素和刪除元素實(shí)例小結(jié)

 更新時(shí)間:2019年06月19日 11:50:43   作者:longzhoufeng  
這篇文章主要介紹了javascript創(chuàng)建元素和刪除元素,結(jié)合實(shí)例形式總結(jié)分析了javascript針對(duì)頁(yè)面元素的動(dòng)態(tài)創(chuàng)建、刪除及子元素操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下

本文實(shí)例講述了javascript創(chuàng)建元素和刪除元素。分享給大家供大家參考,具體如下:

1、創(chuàng)建元素

動(dòng)態(tài)創(chuàng)建新的DOM元素,是js操作網(wǎng)頁(yè)對(duì)象模型的重要手段之一。

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>www.dbjr.com.cn 創(chuàng)建新元素</title>
  <script type="text/javascript">
    //創(chuàng)建新元素
    function createNewElements(){
      //使用innerHTML創(chuàng)建新元素
      var p1 = document.getElementById("p1");
      //設(shè)置innerHTML內(nèi)容
      p1.innerHTML = "<span>我的dom文本1</span>";
      //使用createElement來(lái)創(chuàng)建新元素
      var span = document.createElement("span");
      //為新元素內(nèi)容創(chuàng)建一個(gè)文本節(jié)點(diǎn)
      span.appendChild(document.createTextNode("我的dom文本2"));
      var p2 = document.getElementById("p2");
      //掛接
      p2.appendChild(span);
    }
  </script>
</head>
<body style="text-align:center">
  <p>
    <input type="button" value="創(chuàng)建新元素" onclick="createNewElements()"/>
  </p>
  <!--定義為新元素掛接的容器元素-->
  <p id="p1"></p>
  <p id="p2"></p>
</body>
</html>

運(yùn)行效果:

創(chuàng)建新元素通常有2種方法:

1、直接修改父元素的innerHTML元素;

2、使用createElement()來(lái)創(chuàng)建,再用appendChild()進(jìn)行DOM元素的掛接。

第一種方法用起來(lái)較為簡(jiǎn)單,也易于理解,但需要修改整個(gè)父元素所包含的HTML內(nèi)容,若父元素原先就包含了一些HTML內(nèi)容,再進(jìn)行DOM掛接的話,執(zhí)行效率會(huì)較低;第二種方法相對(duì)較為靈活,效率也較高,只是用起來(lái)復(fù)雜一些。

2、刪除元素

刪除元素指的是把這個(gè)DOM元素徹底刪除,而不是隱藏。通常,使用removeChild()進(jìn)行刪除是最常見(jiàn)的方法。

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>www.dbjr.com.cn 刪除元素</title>
  <script type="text/javascript">
    //刪除元素
    function deleteElement(){
      //獲取準(zhǔn)備刪除的DOM
      var del = document.getElementById("del");
      //調(diào)用刪除函數(shù)徹底刪除
      del.parentNode.removeChild(del);
    }
  </script>
</head>
<body style="text-align:center">
  <p>
    <input type="button" value="刪除元素" onclick="deleteElement()"/>
  </p>
  <!--定義被刪除的元素-->
  <span id="del">即將被刪除的DOM</span>
</body>
</html>

解析:

由于removeChild()是對(duì)子元素的操作,而不是自身的刪除。所以,需要先獲取待刪除元素的父元素,然后再調(diào)用該函數(shù)。本例中,是先使用parentNode屬性獲得待刪除元素的父元素,再刪除目標(biāo)元素。

3、刪除所有的子元素

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>刪除所有的子元素</title>
  <script type="text/javascript">
    //刪除元素的函數(shù)
    function deleteChilds(){
      //獲取父DOM
      var ul = document.getElementsByTagName('ul')[0];
      //判斷是否包含子元素
      if (ul.hasChildNodes()) {
        var len = ul.childNodes.length;     //子元素的個(gè)數(shù)
        for (var i = 0; i < len; i++) {     //遍歷
          ul.removeChild(ul.childNodes[0]);//從第一個(gè)元素開(kāi)始刪除
        }
      }
    }
  </script>
</head>
<body style="text-align:center">
  <ul>
    <li>item1</li>
    <li>item2</li>
    <li>item3</li>
    <li>item4</li>
  </ul>
  </br>
  <input type="button" value="刪除所有的子元素" onclick="deleteChilds()" />
</body>
</html>

解析:刪除子元素,可通過(guò)js提供的removeChild()來(lái)實(shí)現(xiàn)。此外,需要意識(shí)到的另一點(diǎn)是,在遍歷刪除節(jié)點(diǎn)的過(guò)程中,每刪除一個(gè)子元素,子元素的個(gè)數(shù)就會(huì)少一個(gè),因此,示例代碼始終刪除的是第一個(gè)子元素,直到?jīng)]有任何子元素為止。

注:

document.getElementsByTagName(“ul”) 返回的是一個(gè)數(shù)組,后面這個(gè)0是表示這個(gè)數(shù)組的第一個(gè)元素,而本網(wǎng)頁(yè)中ul標(biāo)簽就一個(gè),因此指的就是這個(gè)ul標(biāo)簽了。

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運(yùn)行工具http://tools.jb51.net/code/HtmlJsRun測(cè)試上述代碼運(yùn)行效果。

更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專(zhuān)題:《JavaScript操作DOM技巧總結(jié)》、《JavaScript頁(yè)面元素操作技巧總結(jié)》、《JavaScript事件相關(guān)操作與技巧大全》、《JavaScript查找算法技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)

希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。

相關(guān)文章

最新評(píng)論