
一、DOM简介
DOM是W3C制定的用于访问诸如XML和XHTML等结构化文档的标准。
W3C文档对象模型(DOM)是一个使程序和脚本有能力动态地访问和更新文档的内容、结构以及样式的平台和语言中立的接口
核心DOM:用于任何结构化文档的标准模型
XML DOM:用于XML文档的标准模型。是用于获取、更改、添加或删除XML元素的标准。
HTML DOM: 用于HTML文档的标准模型。定义了所有HTML元素的对象和属性,以及访问它们的方法(接口)。
二、DOM节点
根据DOM规范,文档中的每个成分都是一个节点。DOM的规定:
整个文档是一个文档节点,又称为根节点
每个标签是一个元素节点
包含在标签中的文本是文本节点
标签的每一个属性是一个属性节点
注释属于注释节点
2.1DOM接口及其属性和方法
DOM把文档模拟为一系列节点接口。可通过JavaScript或其他编程语言来访问节点。对
DOM的编程接口是通过一套标准的属性和方法来定义的。
2.1.1DOM属性
一些典型的DOM属性:
x.nodeName:x的名称
x.nodeValue:x的值
x.parentNode:x的父节点,,除了根节点外,只有唯一一个父节点
x.childNodes:x的子节点,可以有多个子节点
x.attributes:x的属性节点集合,可以有多个属性
其中,x是一个节点对象
2.1.2DOM方法
一些典型的DOM方法:
x.getElementsByTagName(name) :获取带有指定标签名称的所有元素
x.appendChild(node) :向x插入子节点
x.removeChild(node) :从x删除子节点
实例:
//获得文档标题的文本内容document.getElementsByTagName("title")[0].childNode[0].nodeValue2.1.3访问节点
<html><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"><title>使用DOM创建并添加节点</title><script type="text/javascript">function createAndAddNode(){//div标签元素节点var container = document.body.getElementsByTagName("div")[0];//创建元素节点对象,元素名即标签名 <p>var pEle = document.createElement("p");//创建文本节点对象,文本内容就是参数值var txtOfP = document.createTextNode("这是段落的文字");//在元素节点内部添加一个文本节点<p>这是段落的文字pEle.appendChild(txtOfP);//在div元素节点后面添加新的子节点。<div><p>这是段落的文字</div>container.appendChild(pEle);//创建一个超链接标签节点var aEle = document.createElement("a");//创建文本节点var txtOfA = document.createTextNode("博客园");//在元素节点中添加文本节点,<a>博客园</a>aEle.appendChild(txtOfA);//创建一个href属性节点var attrOfA = document.createAttribute("href");//将href属性节点设置其属性值attrOfA.nodeValue = "http:www.cnblogs.com";//将属性节点添加到超链接元素节点中,即设置a元素标签的属性节点aEle.setAttributeNode(attrOfA);//将元素节点a添加到div中container.appendChild(aEle);}//浏览器窗口加载时调用该方法window.onload = createAndAddNode;</script></head><body><div></div></body></html>3.3修改节点<html><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"><title>使用DOM改变节点</title><script type="text/javascript">function changeSize(){var target = document.getElementById("txt_1");//设置列的属性值为50target.setAttribute("cols", "50");//设置行的属性值为6 先访问属性节点集合,然后通过getNamedItem定位属性名,target.attributes.getNamedItem("rows").nodeValue = "6";}function changeText() {var target = document.getElementById("lbl_1");//先访问该元素节点的子节点,子节点个数可以是多个,因此用了数组下标访问指定元素。然后通过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删除节点<html><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"><title>使用DOM删除节点</title><script type="text/javascript">function doRemoveNode() {//label标签元素节点var targetLbl = document.getElementById("lbl_1");//从label元素节点中删除第一个子节点targetLbl.removeChild(targetLbl.firstChild);//文档元素,通过访问文档元素集合,指定位置元素获得多行文本域var tagetArea = document.documentElement.getElementsByTagName("textarea")[0];//文档中第一个form标签元素节点var tagetForm = document.documentElement.getElementsByTagName("form")[0];//删除文档中第一个form标签中的textareatagetForm.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="删除节点" onclick="doRemoveNode();"/></form></body></html>四、小结