JavaScript利用HTML DOM進行文檔操作的方法
來源:易賢網 閱讀:773 次 日期:2016-07-15 16:00:50
溫馨提示:易賢網小編為您整理了“JavaScript利用HTML DOM進行文檔操作的方法”,方便廣大網友查閱!

DOM是W3C制定的用于訪問諸如XML和XHTML等結構化文檔的標準。通過本文給大家介紹JavaScript利用HTML DOM進行文檔操作的方法,需要的朋友參考下吧

HTML DOM 樹

名單

一、DOM簡介

DOM是W3C制定的用于訪問諸如XML和XHTML等結構化文檔的標準。

W3C文檔對象模型(DOM)是一個使程序和腳本有能力動態(tài)地訪問和更新文檔的內容、結構以及樣式的平臺和語言中立的接口

核心DOM:用于任何結構化文檔的標準模型

XML DOM:用于XML文檔的標準模型。是用于獲取、更改、添加或刪除XML元素的標準。

HTML DOM: 用于HTML文檔的標準模型。定義了所有HTML元素的對象和屬性,以及訪問它們的方法(接口)。

二、DOM節(jié)點

根據DOM規(guī)范,文檔中的每個成分都是一個節(jié)點。DOM的規(guī)定:

整個文檔是一個文檔節(jié)點,又稱為根節(jié)點

每個標簽是一個元素節(jié)點

包含在標簽中的文本是文本節(jié)點

標簽的每一個屬性是一個屬性節(jié)點

注釋屬于注釋節(jié)點

2.1DOM接口及其屬性和方法

DOM把文檔模擬為一系列節(jié)點接口??赏ㄟ^JavaScript或其他編程語言來訪問節(jié)點。對

DOM的編程接口是通過一套標準的屬性和方法來定義的。

2.1.1DOM屬性

一些典型的DOM屬性:

x.nodeName:x的名稱

x.nodeValue:x的值

x.parentNode:x的父節(jié)點,,除了根節(jié)點外,只有唯一一個父節(jié)點

x.childNodes:x的子節(jié)點,可以有多個子節(jié)點

x.attributes:x的屬性節(jié)點集合,可以有多個屬性

其中,x是一個節(jié)點對象

2.1.2DOM方法

一些典型的DOM方法:

x.getElementsByTagName(name) :獲取帶有指定標簽名稱的所有元素

x.appendChild(node) :向x插入子節(jié)點

x.removeChild(node) :從x刪除子節(jié)點

實例:

//獲得文檔標題的文本內容

document.getElementsByTagName("title")[0].childNode[0].nodeValue

2.1.3訪問節(jié)點

方法一:通過使用getElementsByTagName()方法

方法二:通過循環(huán)遍歷節(jié)點樹

方法三:通過利用節(jié)點的關系在節(jié)點樹中導航

2.1.4節(jié)點信息:

nodeName : 獲取節(jié)點的名稱,是只讀的。

nodeValue: 獲取或設置節(jié)點的值

nodeType:節(jié)點的類型,是只讀的。1,表示元素,2表示屬性,3表示文本,8

表示注釋,9表示文檔

三、節(jié)點操作

3.1創(chuàng)建節(jié)點

createElement(tagName):創(chuàng)建元素節(jié)點

createTextNode(text):創(chuàng)建文本節(jié)點

createAttribute(attrName):創(chuàng)建屬性節(jié)點

3.2添加節(jié)點

新創(chuàng)建的節(jié)點需要與其他已經存在的節(jié)點組織關系,才能讓它真正屬于文檔樹。

appendChild(node) 在當前節(jié)點內部最后一個子節(jié)點后面添加新的子節(jié)點,參數為新的子節(jié)點

insertBefore(newNode,node) 在當前節(jié)點內部指定的子節(jié)點之前添加新的子節(jié)點,第一個參數為新的子節(jié)點,第二個參數為當前節(jié)點內部指定的子節(jié)點

insertAfter()在當前節(jié)點內部指定的子節(jié)點之后添加新的子節(jié)點,第一個參數為新的子節(jié)點,第二個參數為當前節(jié)點內部指定的子節(jié)點

setAttributeNode()在當前元素節(jié)點設置屬性節(jié)點,邀請調用此方法的節(jié)點的類型為元素類型,參數要設置的屬性節(jié)點

示例:

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

<title>使用DOM創(chuàng)建并添加節(jié)點</title>

<script type="text/javascript">

function createAndAddNode(){

//div標簽元素節(jié)點

var container = document.body.getElementsByTagName("div")[0];

//創(chuàng)建元素節(jié)點對象,元素名即標簽名 <p>

var pEle = document.createElement("p");

//創(chuàng)建文本節(jié)點對象,文本內容就是參數值

var txtOfP = document.createTextNode("這是段落的文字");

//在元素節(jié)點內部添加一個文本節(jié)點<p>這是段落的文字

pEle.appendChild(txtOfP);

//在div元素節(jié)點后面添加新的子節(jié)點。<div><p>這是段落的文字</div>

container.appendChild(pEle);

//創(chuàng)建一個超鏈接標簽節(jié)點

var aEle = document.createElement("a");

//創(chuàng)建文本節(jié)點

var txtOfA = document.createTextNode("博客園");

//在元素節(jié)點中添加文本節(jié)點,<a>博客園</a>

aEle.appendChild(txtOfA);

//創(chuàng)建一個href屬性節(jié)點

var attrOfA = document.createAttribute("href");

//將href屬性節(jié)點設置其屬性值

attrOfA.nodeValue = "http:www.cnblogs.com";

//將屬性節(jié)點添加到超鏈接元素節(jié)點中,即設置a元素標簽的屬性節(jié)點

aEle.setAttributeNode(attrOfA);

//將元素節(jié)點a添加到div中

container.appendChild(aEle);

}

//瀏覽器窗口加載時調用該方法

window.onload = createAndAddNode;

</script>

</head>

<body>

<div></div>

</body>

</html>

3.3修改節(jié)點

改變節(jié)點一般指改變元素內部的文本,或改變元素的屬性值。這兩種情況都可以在訪問到文本節(jié)點或屬性節(jié)點后,為其nodeValue賦值來實現更改。對于后者,還可以

在元素節(jié)點上調用setAttribute方法來實現屬性值的改變。

示例:

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

<title>使用DOM改變節(jié)點</title>

<script type="text/javascript">

function changeSize(){

var target = document.getElementById("txt_1");

//設置列的屬性值為50

target.setAttribute("cols", "50");

//設置行的屬性值為6 先訪問屬性節(jié)點集合,然后通過getNamedItem定位屬性名,

target.attributes.getNamedItem("rows").nodeValue = "6";

}

function changeText() {

var target = document.getElementById("lbl_1");

//先訪問該元素節(jié)點的子節(jié)點,子節(jié)點個數可以是多個,因此用了數組下標訪問指定元素。然后通過nodeValue修改其值

target.childNodes[0].nodeValue = "您的個人簡歷:";

}

</script>

</head>

<body>

<form action="">

<label id="lbl_1" for="txt_1">多行文本框的標簽文字</label>

<textarea id="txt_1" ></textarea>

<input type="button" name="btn" value="改變多行文本域的尺寸" onclick="changeSize();" />

<input type="button" name="btn" value="改變標簽的文字" onclick="changeText();" />

</form>

</body>

</html>

3.3刪除節(jié)點

刪除節(jié)點一般指從元素節(jié)點內部刪除子元素或元素包含的文本,也可實現對元素節(jié)點包含的屬性節(jié)點的刪除

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

<title>使用DOM刪除節(jié)點</title>

<script type="text/javascript">

function doRemoveNode() {

//label標簽元素節(jié)點

var targetLbl = document.getElementById("lbl_1");

//從label元素節(jié)點中刪除第一個子節(jié)點

targetLbl.removeChild(targetLbl.firstChild);

//文檔元素,通過訪問文檔元素集合,指定位置元素獲得多行文本域

var tagetArea = document.documentElement.getElementsByTagName("textarea")[0];

//文檔中第一個form標簽元素節(jié)點

var tagetForm = document.documentElement.getElementsByTagName("form")[0];

//刪除文檔中第一個form標簽中的textarea

tagetForm.removeChild(tagetArea);

}

</script>

</head>

<body>

<form>

<label id="lbl_1" for="txt_1">多行文本框的標簽文字</label>

<textarea id="txt_1" rows="" cols=""></textarea>

<input type="button" name="btn" value="刪除節(jié)點" onclick="doRemoveNode();"/>

</form>

</body>

</html>

四、小結

DOM是文檔在內存中表現的樹形結構,稱為DOM樹;DOM是W3C制定的訪問文檔的標準方法和屬性,稱為DOM接口

文檔中的每個數據在樹形結構上表示為一個節(jié)點,由所有節(jié)點組成的樹形結構稱為節(jié)點樹或DOM樹

節(jié)點有多種類型,常見的有元素節(jié)點、屬性節(jié)點、文本節(jié)點、根節(jié)點、等。節(jié)點有名稱和值,但不同類型的節(jié)點其名稱和值含義不同

createElement()方法用于創(chuàng)建元素節(jié)點,createAttribute()方法用于創(chuàng)建屬性節(jié)點,createTextNode()方法用于創(chuàng)建文本節(jié)點,向元素節(jié)點內添加子元素節(jié)點或文本節(jié)點,可使用appendChild()方法。還有insertAfter()和insertBefore()方法用于在特定的節(jié)點前后插入新的節(jié)點。需要注意的是為元素節(jié)點添加屬性節(jié)點的方法卻是setAttributeNode()方法。

要修改文本節(jié)點的值或更改屬性節(jié)點的值,應使用節(jié)點的nodeValue屬性

刪除節(jié)點使用removeChild()方法。

關于JavaScript利用HTML DOM進行文檔操作的方法,小編就給大家介紹這么多,希望對大家有所幫助!

更多信息請查看網絡編程

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網