您好,欢迎访问一九零五行业门户网

Javascript入门学习第八篇 js dom节点属性说明_基础知识

上2篇文章我们讲了 用dom方式 创建节点,复制节点,插入节点, 删除节点,替换节点,查找节点,获取属性等。。。
今天我们讲dom属性。
前面其实我们已经碰过dom属性了。
比如:
nodename,nodetype…..今天我们详细的讲解下。
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将返回这个文本节点的内容。
比如:
<p id="c">aaaaaaaaaaaaaaaa</p>
<script language="javascript">
 var c= document.getelementbyid(c);
 alert(  c.nodevalue  );//返回null
</script>
nodevalue是一个可以读、写的属性。 但它不能设置元素节点的值。
再看看下面的例子:
<p id="c">aaaaaaaaaaaaaaaa</p>
<script language="javascript">
 var c= document.getelementbyid(c);
  c.nodevalue = dddddddddddd; //不能设置
  //alert( c.firstchild.nodevalue ) //元素节点 包括属性节点和文本节点。
  c.firstchild.nodevalue =  test//能设置
</script>
当然我们为了确保能正确运行:可以加一段代码:
<p id="c">aaaaaaaaaaaaaaaa</p>
<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编程技术会有很大的提高。
如果还有不懂,可以google 搜索资料.
其它类似信息

推荐信息