一聚教程网:一个值得你收藏的教程网站

热门教程

DOM属性

时间:2022-07-02 13:48:33 编辑:袖梨 来源:一聚教程网

8, DOM属性:

nodeName属性  : 节点的名字。

如果节点是元素节点,那么返回这个元素的名字。此时,相当于tagName属性。

比如:

aaaa

  : 则返回 p ;

如果是属性节点,nodeName将返回这个属性的名字。

如果是文本节点,nodeName将返回一个#text的字符串。

另外我要说的是: nodeName属性是一个只读属性,不能进行设置.(写)

nodeType属性 : 返回一个整数,代表这个节点的类型。

我们常用的3中类型:

nodeType == 1  : 元素节点

nodeType == 2  : 属性节点

nodeType == 3  : 文本节点

如果想记住的话,上面的顺序我们可以看做是从 前到后。

比如: cssrain" >test

   从前往后读: 你会发现 先是元素节点,然后是属性节点,最后是文本节点,这样你就很容易记住了 nodeType分别代表什么类型了。

nodeType属性经常跟 if 配合使用,以确保不会在错误的节点类型上 执行错误的操作。

比如:

function cs_demo(mynode){

      if(mynode.nodeType == 1){

              mynode.setAttribute("title","demo");

        }

}

代码解释: 先检查mynode的nodeType属性,以确保它所代表的节点确实是 一个元素节点。

和nodeName属性一样,他也是只读属性,不能进行设置.(写)。

nodeValue属性 : 返回一个字符串,这个节点的值。

如果节点是元素节点,那么返回null;(注意下)

如果是属性节点,nodeValue将返回这个属性的值。

如果是文本节点,nodeValue将返回这个文本节点的内容。

比如:

aaaaaaaaaaaaaaaa

 var c= document.getElementById("c");

 alert(  c.nodeValue  );//返回null

nodeValue是一个可以读、写的属性。 但它不能设置元素节点的值。

看下面的例子:

aaaaaaaaaaaaaaaa

 var c= document.getElementById("c");

  c.nodeValue =" dddddddddddd"; //不能设置

  //alert( c.firstChild.nodeValue ) //元素节点 包括属性节点和文本节点。

  c.firstChild.nodeValue =  "test"//能设置

当然我们为了确保能正确运行:可以加一段代码:

aaaaaaaaaaaaaaaa

 var c= document.getElementById("c");

  c.nodeValue =" dddddddddddd"; //不能设置

  //alert( c.firstChild.nodeValue )

  if( c.firstChild.nodeType==3 ){ //判断是不是 文本节点

  c.firstChild.nodeValue =  "test"//能设置

  }

//可以看出,如果要设置元素节点,不能直接设置,而必须先使用firstChild或者lastChild等 然后设置nodeValue.

nodeValue一般只用来设置 文本节点的值。如果要刷新属性节点的值,一般使用setAttribute().

childNodes属性 : 返回一个数组,数组由元素节点的子节点构成。

由于文本节点和属性节点都不可能再包含任何子节点,

所以他们的childNodes属性永远返回一个空数组。

可以使用hasChildNodes方法,它用来判断某个元素有没有子节点。

或者  if (container.childNodes.length < 1) ;

childNodes也是一个只读属性。如果要增加节点,可以使用appendChild()或者insertBefore() , 

删除节点可以使用removeChild(); 操作后,childNodes属性会自动刷新。

firstChild属性 

由于文本节点和属性节点都不可能再包含任何子节点,

所以他们的firstChild属性永远返回一个空数组。 如果没有子节点,将返回null;

 node.firstChild  等价于  node.childNodes[0]  ;

firstChild属性是一个只读属性。

lastChild属性 : 

由于文本节点和属性节点都不可能再包含任何子节点,

所以他们的lastChild属性永远返回一个空数组。 如果没有子节点,将返回null;

 node.lastChild  等价于  node.childNodes[ node.childNodes.length - 1 ]  ;

lastChild属性是一个只读属性。

nextSibling 属性 

返回目标节点的下一个兄弟节点。

如果目标节点后面没有同属于一个父节点的节点,nextSibling 将返回null ;

nextSibling 属性是一个只读属性。

previousSibling属性 

返回目标节点的前一个兄弟节点。

如果目标节点前面没有同属于一个父节点的节点,previousSibling 将返回null ;

previousSibling 属性是一个只读属性。

parentNode 属性 

注:parentNode属性返回的节点永远是一个元素节点,因为只有元素节点才有可能有子节点。

当然有个例外:

document节点,他没有父节点。所以document节点的parentNode属性将返回null;

parentNode 属性是一个只读属性

热门栏目