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

JavaScript DOM元素常見操作詳解【添加、刪除、修改等】

 更新時間:2018年05月09日 11:14:12   作者:LDH-  
這篇文章主要介紹了JavaScript DOM元素常見操作,包括針對dom元素的添加、刪除、修改等相關(guān)操作實現(xiàn)技巧與注意事項,需要的朋友可以參考下

本文實例講述了JavaScript DOM元素常見操作。分享給大家供大家參考,具體如下:

DOM概念

DOM(Document Object Model):文檔對象模型。

通過開發(fā)者工具的Elements標簽頁可以查看

通過開發(fā)者工具的Sources標簽頁也可以觀察到整個文檔是有一系列節(jié)點

整個文檔是由一系列節(jié)點對象組成的一棵樹。

節(jié)點(Node)包括元素節(jié)點(1)、屬性節(jié)點(2)、文本節(jié)點(3)(1..2..3..代表節(jié)點類型)_

var th1= document.getElementById("th1");
alert(th1.nodeType);
alert(th1.nodeName);
alert(th1.nodeValue);

th1代表一個元素節(jié)點(nodeType=1),nodeName就是標簽名(th),元素節(jié)點的nodeValue=null。

var attr1=th1.getAttributeNode("name");
alert(attr1.nodeType);
alert(attr1.nodeName);
alert(attr1.nodeValue);

getAttributeNode方法是獲取元素的屬性節(jié)點,此時輸出的節(jié)點類型為屬性節(jié)點(2),節(jié)點名稱就是屬性名(name),節(jié)點值就是屬性值(sex)

var txtl = th1.firstChild;
alert(txtl.nodeType);
alert(txtl.nodeName);
alert(txtl.nodeValue)

txt1是一個文本節(jié)點(3),節(jié)點名稱固定就是#text,節(jié)點值就是文本內(nèi)容。

獲取元素

(1)getElementByid

根據(jù)元素的id屬性來獲取元素,獲取到的是一個元素。

(2)getElementsByTagName

根據(jù)標簽名來獲取元素,結(jié)果是一個元素集合。

(3)getElementsByClassName

根據(jù)class屬性來獲取元素,結(jié)果是一個元素集合。

(4)getElementsByName

根據(jù)name屬性來獲取元素,結(jié)果是一個元素集合。

總結(jié):獲取元素可以根據(jù)標簽名獲取、也可以根據(jù)id、name、class屬性來獲取。根據(jù)id屬性獲取的結(jié)果是一個元素,而其它的獲取的是一個集合。

document對象支持以上四種,而element對象僅支持getElementsByTagNamegetElementsByClassName

修改元素

(1)修改內(nèi)容

function fun(){
  //獲取到指定元素
  var p1 = document.getElementById("p1");
  p1.innerText = "我被單擊了!";
}

通過.innerText屬性可讀取或設(shè)置標簽的內(nèi)容文本

function fun(){
  //獲取到指定元素
  var p1 = document.getElementById("p1");
  p1.innerHTML = "我被單擊了!<br>換行了";
}

也可以通過innerHTML屬性獲取或設(shè)置內(nèi)容文本

倆者的區(qū)別:innerHTML會按照HTML規(guī)則解析文本,而innerText只是當做普通文本內(nèi)容。

(1)  修改樣式

A.xxx.style.屬性名=“值”

B.xxx.classname=“…”(相當于修改了class的屬性)

<style>
    .style1{
      color:red;
      font-size:20px;
      text-decoration:underline;
    }
    .style2{
      color:blue;
      font-size:32px;
      text-decoration:line-through;
    }
  </style>
</head>
<body>
<p id="p1">修改樣式測試</p>
<input type="button"value="樣式一"onclick="style1()">
<input type="button"value="樣式二"onclick="style2()">
</body>
<script>
  var p1 = document.getElementById("p1");
  function style1(){
    p1.className = "style1"
  }
  function style2(){
    p1.className = "style2"
  }
</script>
</html>

添加刪除元素

(1)CreateElement建一個元素節(jié)點

CreateElement("p")創(chuàng)建一個段落

(2)createTextNode創(chuàng)建一個文本節(jié)點

createTextNode("文本內(nèi)容"),創(chuàng)建一個值為“文本內(nèi)容”的文本節(jié)點.

(3)appendChild添加子節(jié)點

(4)removeChild  刪除子節(jié)點

動態(tài)添加

<body>
<div id="div1">
</div>
<input type="button"value="添加段落"onclick="add()">
</body>
<script>
//全局變量
  var index = 1;
  function add(){
    //創(chuàng)建一個段落標簽
    var p = document.createElement("p");
    //創(chuàng)建文本節(jié)點
    var content= "第"+index+"段落";
    var txt = document.createTextNode(content);
    //創(chuàng)建文本節(jié)點添加的段落
    p.appendChild(txt);
    //將段落添加到div中
    var div1 = document.getElementById("div1");
    div1.appendChild(p);
    index++
  }
</script>

動態(tài)刪除

<body>
<div id="div1">
  <p id="p1">第1段落 </p>
  <p id="p2">第2段落 </p>
  <p id="p3">第3段落 </p>
  <p id="p4">第4段落 </p>
</div>
<input type="button"value="刪除第二段"onclick="del()">
</body>
<script>
  function del(){
    //先找到父節(jié)點
    var div1 = document.getElementById("div1");
    //再找到要刪除的節(jié)點
    var p2 = document.getElementById("p2");
    //將要刪除的節(jié)點從父節(jié)點中移除
    div1.removeChild(p2);
  }
</script>
</html>

這種方法是分別找到父節(jié)點和要刪除的節(jié)點,然后執(zhí)行刪除操作。該方法的一個前提是知道父節(jié)點是誰

那么如果并不知道父節(jié)點是誰,該如何刪除呢

p2.parentNode.removeChild(p2);

這個方法并不需要父節(jié)點是誰

動態(tài)的添加和刪除:

動態(tài)添加和動態(tài)刪除,刪除動態(tài)添加的奇數(shù)段落

思路1:獲取div1 下的所以段落,遍歷所以的段落,將序號為奇數(shù)的段落刪除。

function del(){
  var div1 = document.getElementById("div1");
  var paras = div1.getElementsByTagName("p");
  for(var i in paras){
    if((i+1)%2 == 1){
      div1.removeChild(paras[i]);
    }
  }
}

這種在初始時是可以的,但是隨著動態(tài)添加或刪除的進行,后面的結(jié)果就不對了。因為動態(tài)刪除操作就影響了原來的順序,而程序是按照序號去判斷奇偶性,所以出現(xiàn)誤判

思路2:添加通過設(shè)置class屬性,然后通過getElementsByclassName來獲取奇數(shù)行

(也可以從后往前刪)

<body>
<div id="div1">
</div>
<input type="button" value="添加段落" onclick="add()">
<input type="button" value="刪除奇數(shù)第二段" onclick="de1()">
</body>
<script>
  var index = 1;
  function add(){
    //創(chuàng)建一個段落標簽
    var p = document.createElement("p");
    //創(chuàng)建文本節(jié)點
    var content = "第" + index + "段落";
    var txt = document.createTextNode(content);
    //將文本節(jié)點添加到段落
    p.appendChild(txt);
    if (index % 2 == 1) {
      p.setAttribute("class","odd");
    }
    //將段落添加到div中
    var div1 = document.getElementById("div1");
    div1.appendChild(p);
    index++;
  }
  /*function de1(){
   var div1 = document.getElementById("div1");
   var paras =div1.getElementsByTagName("p");
   for(var i in paras){
   if((i+1)%2 == 1){
   div1.removeChild(paras[i]);
   }
   }
   }*/
  functionde1() {
    var div1 = document.getElementById("div1");
    var paras = div1.getElementsByClassName("odd");
//    varparas = document.getElementsByName("odd");
    for (var i = paras.length - 1; i >= 0; i--) {
      div1.removeChild(paras[i]);
    }
  }
</script>
</html>

導(dǎo)航

Document:是根節(jié)點

ParentNode:獲取父節(jié)點

childNodes:獲取所有子節(jié)點

firstChild:第一個子節(jié)點

lastChlid:獲取最后一個子節(jié)點

</head>
<body>
<div name="第一章">
   <p id="p1">第一段<span>第一句</span><span>第二句</span></p>
</div>
<input type="button"value="獲取父節(jié)點的name屬性"onclick="fun1()">
<input type="button"value="顯示p1子節(jié)點的個數(shù)"onclick="fun2()">
<input type="button"value="顯示p1第一個子節(jié)點的類型"onclick="fun3()">
<input type="button"value="顯示p1最后一個子節(jié)點的類型"onclick="fun4()">
</body>
<script>
var p1 =document.getElementById("p1");
function fun1(){
  var value=p1.parentNode.getAttribute("name");
  alert(value);
}
function fun2(){
  var chlids = p1.childNodes;
  alert(chlids.length)
}
function fun3(){
  alert(p1.firstChild.nodeType);
}
function fun4(){
  alert(p1.lastChild.nodeType);
}
</script>
</html>

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript操作DOM技巧總結(jié)》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學運算用法總結(jié)

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

相關(guān)文章

  • JavaScript純前端實現(xiàn)在線GIF壓縮

    JavaScript純前端實現(xiàn)在線GIF壓縮

    這篇文章主要為大家詳細介紹了如何利用JavaScript純前端實現(xiàn)在線GIF壓縮工具,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2024-03-03
  • 淺談時鐘的生成(js手寫簡潔代碼)

    淺談時鐘的生成(js手寫簡潔代碼)

    下面小編就為大家?guī)硪黄獪\談時鐘的生成(js手寫簡潔代碼)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-08-08
  • JavaScript解決浮點數(shù)計算不準確問題的方法分析

    JavaScript解決浮點數(shù)計算不準確問題的方法分析

    這篇文章主要介紹了JavaScript解決浮點數(shù)計算不準確問題的方法,結(jié)合實例形式分析了javascript浮點數(shù)運算精度誤差的原因以及相關(guān)的解決方法與具體操作技巧,需要的朋友可以參考下
    2018-07-07
  • JS寫XSS cookie stealer來竊取密碼的步驟詳解

    JS寫XSS cookie stealer來竊取密碼的步驟詳解

    JavaScript是web中最常用的腳本開發(fā)語言,js可以自動執(zhí)行站點組件,管理站點內(nèi)容,在web業(yè)內(nèi)實現(xiàn)其他有用的函數(shù)。這篇文章主要介紹了JS寫XSS cookie stealer來竊取密碼的步驟詳解,需要的朋友可以參考下
    2017-11-11
  • 如何使用js獲取擴展名詳解

    如何使用js獲取擴展名詳解

    給你一個文件名,你能獲得它的擴展名嗎?這篇文章主要給大家介紹了關(guān)于如何使用js獲取擴展名的相關(guān)資料,文中介紹了幾種實現(xiàn)的方法,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2022-02-02
  • javascript 原型鏈維護和繼承詳解

    javascript 原型鏈維護和繼承詳解

    本文通過實例詳細向我們分析了javascript原型鏈維護和繼承的問題,十分的詳盡,十分的全面,這里推薦給大家。
    2014-11-11
  • javascript設(shè)計模式 – 觀察者模式原理與用法實例分析

    javascript設(shè)計模式 – 觀察者模式原理與用法實例分析

    這篇文章主要介紹了javascript設(shè)計模式 – 觀察者模式,結(jié)合實例形式分析了javascript觀察者模式相關(guān)概念、原理、用法及操作注意事項,需要的朋友可以參考下
    2020-04-04
  • Bootstrap實現(xiàn)登錄校驗表單(帶驗證碼)

    Bootstrap實現(xiàn)登錄校驗表單(帶驗證碼)

    本文給大家介紹使用Bootstrap新制作的一個登錄框,帶驗證碼,帶校驗,非常不錯,具有參考借鑒價值,感興趣的朋友可以參考下
    2016-06-06
  • javascript 一段左右兩邊隨屏滾動的代碼

    javascript 一段左右兩邊隨屏滾動的代碼

    在不少的網(wǎng)站使用了這種技術(shù),一般就是兩邊的一些三個小塊排一起的廣告。
    2009-06-06
  • ES6新特性八:async函數(shù)用法實例詳解

    ES6新特性八:async函數(shù)用法實例詳解

    這篇文章主要介紹了ES6新特性八:async函數(shù)用法,結(jié)合實例形式分析了async函數(shù)的功能、原理、使用方法與相關(guān)注意事項,需要的朋友可以參考下
    2017-04-04

最新評論