Javascript学习第一季(8)

来源:互联网 发布:电脑网络usb共享给手机 编辑:程序博客网 时间:2024/05/16 17:04
1,nodeName属性 : 节点的名字。 
如果节点是元素节点,那么返回这个元素的名字。此时,相当于tagName属性。 
比如: 
<p>aaaa</p> : 则返回 p ; 
如果是属性节点,nodeName将返回这个属性的名字。 
如果是文本节点,nodeName将返回一个#text的字符串。 


另外我要说的是: nodeName属性是一个只读属性,不能进行设置.(写) 
它返回 大写字母的值。 


2,,nodeType属性 : 返回一个整数,代表这个节点的类型。 
我们常用的3中类型: 
nodeType == 1 : 元素节点 
nodeType == 2 : 属性节点 
nodeType == 3 : 文本节点 
如果想记住的话,我们可以这么去记: 
比如: <p title="cssrain" >test</p>   从前往后读: 你会发现 先是元素节点(1),然后是属性节点(2),最后是文本节点(3),这样你就很容易记住了 nodeType分别代表什么类型了。(我总结的一点小技巧, ^_^。) 


nodeType属性经常跟 if 配合使用,以确保不会在错误的节点类型上 执行错误的操作。 
比如: 
function cs_demo(mynode){ 
      if(mynode.nodeType == 1){ 
              mynode.setAttribute("title","demo"); 
        } 

代码解释: 先检查mynode的nodeType属性,以确保它所代表的节点确实是 一个元素节点。 
和nodeName属性一样,他也是只读属性,不能进行设置.(写)。 


3,nodeValue属性 : 返回一个字符串,这个节点的值。 
如果节点是元素节点,那么返回null;(注意下) 
如果是属性节点,nodeValue将返回这个属性的值。 
如果是文本节点,nodeValue将返回这个文本节点的内容。 
比如: 
<div id="c">aaaaaaaaaaaaaaaa</div> 
<SCRIPT LANGUAGE="JavaScript"> 
var c= document.getElementById("c"); 
alert( c.nodeValue );//返回null 
</SCRIPT> 
nodeValue是一个可以读、写的属性。 但它不能设置元素节点的值。 
再看看下面的例子: 
<div id="c">aaaaaaaaaaaaaaaa</div> 
<SCRIPT LANGUAGE="JavaScript"> 
var c= document.getElementById("c"); 
c.nodeValue =" dddddddddddd"; //不能设置 
//alert( c.firstChild.nodeValue ) //元素节点 包括属性节点和文本节点。 
c.firstChild.nodeValue = "test"//能设置 
</SCRIPT> 
当然我们为了确保能正确运行:可以加一段代码: 
<div id="c">aaaaaaaaaaaaaaaa</div> 
<SCRIPT LANGUAGE="JavaScript"> 
var c= document.getElementById("c"); 
c.nodeValue =" dddddddddddd"; //不能设置 
//alert( c.firstChild.nodeValue ) 
if( c.firstChild.nodeType==3 ){ //判断是不是 文本节点 
c.firstChild.nodeValue = "test"//能设置 

</SCRIPT> 
//可以看出,如果要设置元素节点,不能直接设置,而必须先使用firstChild或者lastChild等 然后设置nodeValue. 
nodeValue一般只用来设置 文本节点的值。如果要刷新属性节点的值,一般使用setAttribute(). 


4, childNodes属性 : 返回一个数组,数组由元素节点的子节点构成。 
由于文本节点和属性节点都不可能再包含任何子节点, 
所以他们的childNodes属性永远返回一个空数组。 


可以使用hasChildNodes方法,它用来判断某个元素有没有子节点。 
或者 if (container.childNodes.length < 1) ; 


childNodes也是一个只读属性。如果要增加节点,可以使用appendChild()或者insertBefore() , 
删除节点可以使用removeChild(); 
操作后,childNodes属性会自动刷新。 


5, firstChild属性 : 
由于文本节点和属性节点都不可能再包含任何子节点, 
所以他们的firstChild属性永远返回一个空数组。 如果没有子节点,将返回null; 
node.firstChild 等价于 node.childNodes[0] ; 
firstChild属性是一个只读属性。 




6 , lastChild属性 : 
由于文本节点和属性节点都不可能再包含任何子节点, 
所以他们的lastChild属性永远返回一个空数组。 如果没有子节点,将返回null; 
node.lastChild 等价于 node.childNodes[ node.childNodes.length - 1 ] ; 
lastChild属性是一个只读属性。 


7 , nextSibling 属性 : 
返回目标节点的下一个兄弟节点。 
如果目标节点后面没有同属于一个父节点的节点,nextSibling 将返回null ; 
nextSibling 属性是一个只读属性。 


8 , previousSibling属性 : 
返回目标节点的前一个兄弟节点。 
如果目标节点前面没有同属于一个父节点的节点,previousSibling 将返回null ; 
previousSibling 属性是一个只读属性。 


9 , parentNode 属性 : 
注:parentNode属性返回的节点永远是一个元素节点,因为只有元素节点才有可能有子节点。 
当然有个例外: 
document节点,他没有父节点。所以document节点的parentNode属性将返回null; 
parentNode 属性是一个只读属性。 


好了,DOM的常用属性和方法说到这里,了解这些方法的使用, 
相信大家的DOM编程技术会有很大的提高。