JavaScript : DOM文档解析详解

简介:

JavaScript DOM  文档解析

 

1、节点(node):来源于网络理论,代表网络中的一个连接点。网络是由节点构成的集合

  <p title=“a gentle reminder”> Don’t forget to buy this stuff.</p>

  节点及其类型

  元素节点:

  属性节点:元素的属性,可以直接通过属性的方式来操作

  文本节点:元素节点的子节点,其内容通常为文本

 

2、Node接口的特性和方法

 

现在给出一个演示的HTML文件:

复制代码
html
<!doctype html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <title>DOM文档解析</title>
    <script type="text/javascript">
        window.onload=function() {
            进行下面的事件处理.....
        }
    </script>
</head>
<body>
    <p id="ele">兴趣爱好:</p>
    <ul id ="favorite">
        <li id="movie">电影</li>
        <li id="music">音乐</li>
    </ul>
    <p id="ele">教学科目:</p>
    <ul id="education">
        <li id="subject" name="subject">语文</li>
        <li id="subject" name="subject">数学</li>
        <li id="subject" name="subject">英语</li>
    </ul>
    <br>
    文本框:<input type="text" id="inputText" name="inputText" value="China">
</body>
</html>
复制代码

 

3、获取元素节点

  1) document.getElementById(‘Id’):根据id的属性获取对应的单个节点

var eleNode = document.getElementById("textInput");
alert(eleNode.value); //china

  2) document.all(‘id’):根据id的属性获取对应的节点集合

var eleNode = document.all("ele");
alert(eleNode.length); // 2

  3) document.getElementsByTagName(‘tagName’):根据标签名称获取指定节点集合     

var eleNode = document.getElementsByTagName("li");
alert(eleNode.length);  //5                

  4) document.getElementsByName(‘name’):根据节点的name属性获取符合的节点集合

var eleNode = document.getElementsByName("subject");
alert(eleNode.length); //3

 

4、读写属性节点

     1) 可以直接通过Node.属性这样的方式来获取和设置属性节点的值

var eleNode = document.getElementById("textInput"); //元素节点
alert(eleNode.value); //china
eleNode.value = "America"; //重新设置值
alert(eleNode.value); //America

    2) 通过元素节点的getAttributeNode(‘属性’)方法来获取属性节点,然后再通过nodeValue来读写属性值

var eleNode = document.getElementById("textInput");//元素节点
var paraNode = eleNode.getAttributeNode("value");  //属性节点
alert(paraNode.nodeValue); //china
paraNode.nodeValue = "America";//重新设置值
alert(paraNode.nodeValue); //America  

 

5、获取元素节点的子节点(只有属性节点才有子节点)

     1) childNodes 属性获取全部的子节点,但该方法不实用,因为如果要获取指定的节点的指定子节点的集合,可以直接调用元素节点的getElementsTagName()方法来获取。  

复制代码
var eleNode = document.getElementById("favorite");   
var childNodes = eleNode.childNodes;      
alert(childNodes.length); //5,该方法不实用
var eleNode = document.getElementById("favorite");
var childNodes = eleNode.getElementsByTagName("li");
alert(childNodes.length);//2 ,方法很实用
复制代码

     2)firstChild  属性获取第一个子节点

var eleNode = document.getElementById("favorite");
alert(eleNode.firstChild);//[object Text] ,方法很实用

     3)lastChild   属性获取最后一个子节点

var eleNode = document.getElementById("favorite");
alert(eleNode.lastChild); //[object Text] ,方法很实用

 

6、读写文本节点:获取文本节点,文本节点一定是元素节点的子节点

    1)步骤:元素节点——>获取元素节点的子节点

复制代码
//1.获取文本节点所在的元素节点
var liNodes = document.getElementsByTagName("li");
//2.获取元素节点的子节点,即文本节点
for (var i = 0; i < liNodes.length; i++) {
    var liTextNodes = liNodes[i].childNodes;
    alert(liTextNodes.length);// 1 1 1 1 1
}
复制代码

    2)若元素节点只有文本节点一个子节点,例如<li id="movie">电影</li>

       可以先获取到指定的元素节点eleNode,

       再利用eleNode.firstChild.nodeValue的方法来读写文本节点的值

复制代码
 //1.获取文本节点所在的元素节点
var movieNode = document.getElementById("movie");

//2.通过firstChild定义到文本节点
var movieTextNode = movieNode.firstChild;
alert(movieTextNode); //[object text]

//3.通过操作文本节点的nodeValue属性读写文本节点的属性值   
alert(movieTextNode.nodeValue); //电影
movieTextNode.nodeValue = "爬山";//重新设置值
alert(movieTextNode.nodeValue); //爬山
复制代码

 

7、节点的属性

     1)nodeName:代表当前节点的名字,只读属性。

     2)nodeType:返回一个整数,这个数值代表者给定节点的类型,只读属性

     3)nodeValue:返回给定节点的当前值(字符串)。可读可写属性 

    由于节点可以分为元素节点,属性节点和文本节点,而这些节点又有三个非常有用的属性,nodeName属性和 nodeType属性是只读,而nodeValue属性是可以读写的:

    元素节点:

var pNode = document.getElementById("ele");
alert(pNode.nodeType);  // 元素节点:1
alert(pNode.nodeName);  // 元素节点名:p
alert(pNode.nodeValue); // 元素节点没有nodeValue值:null

     属性节点:

var nameAttrNode = document.getElementById("inputText").getAttributeNode("name");
alert(nameAttrNode.nodeType);  // 属性节点:2
alert(nameAttrNode.nodeName);  // 属性节点名:name
alert(nameAttrNode.nodeValue); // 属性节点的nodeValue就是属性值本身: inputText

     文本节点:      

musicNode = document.getElementById("music");
musicTextNode = musicNode.firstChild;
alert(musicTextNode.nodeType);  // 文本节点:3
alert(musicTextNode.nodeName);  // 文本节点名:#text
alert(musicTextNode.nodeValue); // 文本节点值:音乐

 

8、创建一个元素节点

   1)createElement():按照给定的标签名创建一个新的元素节点,方法只有一个参数.

     被创建的元素节点的名字,是一个字符串。  

     方法的返回值:是一个指向新建节点的引用指针。返回值是一个元素节点,所以它的nodeType属性值是1.

      **新元素不会自动添加到文档里,它只是一个存在于JavaScript上下文的对象.  

 //新创建一个元素节点,并把该节点添加到文档中指定节点的子节点,并作为指定节点的最后一个子节点
var liNode = document.createElement("li");
var favoriteNode = document.getElementById("favorite");
favoriteNode.appendChild(liNode);  //多了一个不带文本节点的子节点 

 

9、创建一个文本节点

    1) createTextNode():创建一个包含着给定文本的新文本节点。

        这个方法的返回值是一个指向新节点的引用指针。

        方法只有一个参数,新建文本节点所包含的文本字符串。新元素节点不会自动添加到文档里。

复制代码
//新创建一个元素节点,并把该节点添加到文档中指定节点的子节点,并作为指定节点的最后一个子节点
var liNode = document.createElement("li");
var favoriteNode = document.getElementById("favorite");
favoriteNode.appendChild(liNode);

//新建一个"读书"文本节点,并把它添加到元素节点中
var readTextNode = document.createTextNode("读书");
liNode.appendChild(readTextNode); //多了一个”读书”文本节点的子节点
复制代码

 

10、为元素节点添加子节点

    1) appendChild(): var reference = element.appendChild(newChild):

      给定子节点newChild将成为给定元素节点element的最后一个子节点。

      方法的返回值是一个指向新增子节点的引用指针。

      例如上面的: 

favoriteNode.appendChild(liNode);
liNode.appendChild(readTextNode);

 

11、节点的替换

    1) replaceChild():把一个给定父元素里的一个子节点替换成另外一个子节点.

      var refrence = element.replaceChild(newChild,oldChild);

      该节点处了替换功能以外还有移动功能;

复制代码
//取出元素节点
var ulNode = document.getElementById("education");
var movieNode = document.getElementById("movie");
var liNodes = document.all("subject");

//全部替换
for (var i = 0; i < liNodes.length; i++) {
    ulNode.replaceChild(movieNode,liNodes[i]);  //科目子节点被替换成了”电影”这个节点,同时位置也移动了
}    
复制代码

   2) 该方法只能完成单向替换,若需要使用双向替换,需要自定义函数。 

复制代码
//实现movie和music节点的互换
var ulNode = document.getElementById("favorite");

//获取movie节点和music节点
var movieNode = document.getElementById("movie");
var musciNode = document.getElementById("music");

//克隆movieNode
var movieNode2 = movieNode.cloneNode(true); //true:表示连它的子节点都克隆

//互换一下位置
ulNode.replaceChild(movieNode2,musciNode);
ulNode.replaceChild(musciNode,movieNode); //此时,“电影”和“音乐”就互换了 
复制代码

 

12、删除节点

    1) removeChild():从一个给定元素里删除一个子节点

     var reference = element.removeChild(node)

     返回值是一个指向已被删除的子节点的引用指针,某个节点被removeChild()方法删除时,这个节点所包含的所有子节点将同时被删除。如果想删除某一个节点,但不知道他的父节点是哪一个,parentNode属性可以帮忙。 

复制代码
//获取id为"music"的子节点musicNode
var musicNode = document.getElementById("music");

//获取父节点ulNode
//var ulNode = document.getElementById("favorite");
var ulNode = musicNode.parentNode;

//删除musicNode子节点
ulNode.removeChild(musicNode); //此时“音乐”这个节点就消失了
复制代码

 

13、插入节点

    1)insertBefore():把一个给定节点插入到一个给定元素节点的给定子节点前面

      var reference = element.insertBefore(newNode,targetNode)的前面。

      节点targetNode必须是element元素的一个节点。 

复制代码
//取出musicNode
var musicNode = document.getElementById("music");

//取出movieNode
var movieNode = document.getElementById("movie");

//将musicNode插入到movieNode前面
musicNode.parentNode.insertBefore(musicNode,movieNode); //此时,“音乐”节点就插入到了“电影”节点前面
复制代码

2) 自定义insertAfter(newNode,refNode)方法

  思路:<1>测试refNode是否为其父节点的一个子节点

     <2>如是:直接把newNode插入到refNode父节点的最后一个子节点,使用appendChild()方法即可

     <3>如不是:获取一个refNode的下一个兄弟节点,然后插入到其下一个兄弟节点的前面

复制代码
window.onload=function() {
    //取出musicNode
    var musicNode = document.getElementById("music");

    //取出movieNode
    var movieNode = document.getElementById("movie");

    //将movieNode插入到musicNode后面    
    insertAfter(movieNode,musicNode); //此时,“电影”节点就插入到了“音乐”节点后面
}

function insertAfter(newNode,refNode) {
    refNode.parentNode.appendChild(newNode);
}
复制代码

 

总结:

一、获取元素节点经常使用的方法:

       (1)使用getElementById()方法通过id属性获取对应的单个元素节点。推荐使用。

       (2)使用getElementByTagName()方法根据标签获取指定元素节点名字的数组,数组对象length属性可以获取数组

的长度。推荐使用。

       (3)使用getElementsByName()方法根据name属性获取对应的表单元素节点。这里要注意是符合的表单元素中的

name属性的值。获取表单元素时推荐使用。

 

二、获取元素节点的子节点(只有元素节点才有子节点)我们通常使用

       (1)首先是先利用获取元素节点的方法获取到元素节点,再使用childNodes属性获取全部的子节点对象数组列表,

注意不兼容性和空白文本节点。不推荐使用。

       (2)首先是先利用获取元素节点的方法获取到元素节点,再使用firstChild属性与lastChild属性获取元素节点的第一

个子节点和最后一个子节点。这里也要注意空白文本节点。推荐使用。

       (3)首先利用获取元素节点的方法获取元素节点,再利用children属性获取所有它的所有有效子节点对象数组列

表。推荐使用。

       (4)首先使用获取元素节点的方法获取到指定的元素节点,再使用getElemensByTagName()方法获取所有的子元

素节点对象数组列表。推荐使用。

 

三、获取属性节点

       (1)由于属性节点时某一指定元素节点的属性,可以通过先使用getElementById()方法通过id属性获取对应的单个

元素节点再利用“元素节点.属性”这样的方式来获取和设置属性节点的值。推荐使用。

       (2)先利用获取元素节点的方法获取到元素节点,再使用Attribute属性返回该节点的属性节点集合。但是要注意浏

览器的兼容性。这种不推荐使用。

 

四、获取文本节点(文本节点时元素节点的子节点)

       (1)首先也是利用获取元素节点的方法获取到元素节点,再利用元素节点的属性innerHTML属性得到文本节点中的

文本内容。推荐使用。

       (2)如果指定的元素节点中只有一个子节点,也就是该子节点是文本节点,可以先获取文本节点所在的元素节点,

再利用firstChild属性定位到文本节点,最后通过文本节点的nodeValue属性获取文本节点中的文本内容。推荐使用。

 

五、获取body元素节点

       (1)使用document.getElemensByTagName("body")[0]获取body元素节点。

       (2)使用document.body获取body元素节点。推荐使用。

 

 

 

程序猿神奇的手,每时每刻,这双手都在改变着世界的交互方式!
本文转自当天真遇到现实博客园博客,原文链接:http://www.cnblogs.com/XYQ-208910/p/5856127.html ,如需转载请自行联系原作者
相关文章
|
4天前
|
XML Web App开发 JavaScript
XML DOM 解析器
大多数浏览器内置XML解析器,将XML转化为JavaScript可访问的XML DOM对象。XML DOM提供遍历、访问、插入和删除节点的功能。文档须先加载至DOM。示例代码通过XMLHTTP请求加载`books.xml`,兼容多种浏览器,响应设置为XML DOM用于后续处理。
|
4天前
|
XML Web App开发 JavaScript
XML DOM 解析器
**XML DOM解析器将XML转换为JS对象,便于操作。浏览器内置XML解析器,通过XMLHttpRequest或ActiveXObject加载XML如&quot;books.xml&quot;。
|
9天前
|
搜索推荐 网络架构 开发者
Next.js静态出口生成策略深度解析
【7月更文挑战第18天】Next.js凭借其强大的静态生成、静态出口生成以及服务器端渲染功能,为开发者提供了构建高性能、高SEO友好Web应用的强大工具。
|
16天前
|
JSON JavaScript 前端开发
DVWA JavaScript 通关解析
DVWA JavaScript 通关解析
|
12天前
|
XML Web App开发 JavaScript
XML DOM 解析器
**XML DOM解析器内置于多数浏览器中,将XML转换为可操作的JavaScript对象。通过遍历、访问和修改节点的方法,XML文档加载到DOM后,可用JavaScript处理。
|
15天前
|
XML Web App开发 JavaScript
XML DOM 解析器
XML DOM解析器将XML转换为JavaScript对象,允许遍历、修改节点。浏览器内置XML解析器,如XMLHttpRequest用于加载XML文档。
|
2天前
|
XML Web App开发 JavaScript
XML DOM 解析器
Most browsers have a built-in XML parser to create an XML DOM object from XML, making it accessible via JavaScript. The XML DOM includes methods for navigating, accessing, inserting, and deleting nodes in the XML tree.
|
7天前
|
XML Web App开发 JavaScript
XML DOM 解析器
**XML DOM解析器**在浏览器中内置,将XML转换为可操作的对象。通过遍历、访问和修改节点来处理XML。首先,XML文档加载到DOM对象,如JavaScript的`responseXML`属性所示。
|
9天前
|
XML Web App开发 JavaScript
XML DOM 解析器
**XML DOM解析器**在浏览器中内置,将XML转换为可操作的对象。通过遍历、添加或删除节点的方法,XML文档被加载到DOM以便JavaScript访问。以下JS代码示例加载&quot;books.xml&quot;: ```markdown - 创建XMLHttpRequest或ActiveXObject(针对旧版IE) - 打开GET请求到&quot;books.xml&quot; - 发送请求 - 设置响应为`responseXML`,成为DOM对象 ``` 这段代码展示了如何在不同浏览器上异步加载XML文档到DOM。
|
10天前
|
XML Web App开发 JavaScript
XML DOM 解析器
**XML DOM解析器将XML转换为JS对象,允许遍历、修改文档。浏览器通常内置XML解析器,如JavaScript的XMLHttpRequest。

推荐镜像

更多