作为一个js-dom开发者,你必须知道的一些dom方法:
1, 创建节点。
createelement():
var a = document.createelement(“p”);
它创建的是一个元素节点,所以 nodetype 等于 1 。
a.nodename 将返回 p ;
注意;createelement()方法创建出来的新元素节点不会被自动添加到文档里,既然没添加到文档里,说明它还是一个游离的状态。所以它也没有nodeparent属性。
如果想把它添加到文档里,可以使用 appendchild()或者insertbefore()方法或者replacechild()方法。当然我们在前面的例子中,自己写了一个insertafter()方法;
比如:
var a = document.createelement(“p”);
document.body.appendchild(a);
注意: appendchild()默认是添加到文档的最后。也就是lastchild子节点。
如果想添加到某个地方,可以使用insertbefore()。
如果想在元素插入之前给元素添加属性。可以这么做:
var a = document.createelement(“p”);
a.setattribute(“title”,”my demo”);
document.body.appendchild(a);
createtextnode():
var b = document.createtextnode(“my demo”);
它创建的是一个文本节点,所以nodetype等于 3 。
b.nodename 将返回 #text ;
跟createelement()一样,用createtextnode()创建的节点也不会自动添加到文档里。需要使用appendchild()或者insertbefore()方法或者replacechild()方法。
他经常与createelement()配合使用,知道为什么吗?(一个元素节点,一个文本节点。)
var mes = document.createtextnode(“hello world”);
var container = document.createelement(“p”);
container.appendchild(mes);
document.body.appendchild(container);
2, 复制节点。
clonenode(boolean) :
它有一个参数。
var mes = document.createtextnode(hello world);
var container = document.createelement(p);
container.appendchild(mes);
document.body.appendchild(container);
var newpara = container.clonenode(true);//true和false的区别
document.body.appendchild(newpara );
注意:
true的话:是<p>aaaa</p> 克隆。
false: 只克隆 <p></p> ,里面的文本不克隆。
可以自己写个例子,然后用 firebug 看看。
克隆后的新节点,和createtextnode()一样 不会被自动插入到文档 。需要appendchild();
另外还有一个注意: 如果克隆后,id一样,不要忘记用 setattribute(“id” , “ another_id “);
改变新的节点的id。
3, 插入节点。
appendchild() :
给元素追加一个子节点, 新的节点 插入到 最后。
var container = document.createelement(p);
var t = document.createtextnode(cssrain);
container.appendchild(t);
document.body.appendchild(container);
他经常跟createelement()和createtextnode(),clonenode()配合使用。
另外 appendchild()不仅可以用来追加新的元素,也可以你 挪动 文档中现有的元素。
看下面的例子:
<p id="msg">msg</p>
<p id="content">content</p>
<p id="aaa">aaaaaaaa</p>
<script>
var mes = document.getelementbyid(msg);
var container = document.getelementbyid(content);
container.appendchild(mes);
</script>
//发现msg放到 content 后面去了 。
js内部处理方式:
先把id为msg的从文档中删除,然后再插入到content 后,作为content的最后一个节点。
结果为:
<p id="content">
content
<p id="msg">msg</p>
</p>
<p id="aaa">aaaaaaaa</p>
insertbefore() :
顾名思义,就是把一个新的节点插入到目标节点的前面。
element.insertbefore( newnode , targernode );
第二个参数是可选,如果第二个参数不写,将默认添加到文档的最后,相当于appendchild();
我们看看insertbefore()怎么使用:
<p id="cssrian">
<p id="content">1111</p>
<p id="msg">msg<p>test</p></p>
<p id="content">222</p>
<p id="aaa">aaaaaaaa</p>
</p>
<script>
var msg = document.getelementbyid(msg);
var aaa = document.getelementbyid(aaa);
var test = document.getelementbyid(cssrian);
test.insertbefore( msg , aaa );
</script>
// 我们发现id为msg的 插入到了 aaa的前面。
js内部处理方式跟 appendchild()相似。
4, 删除节点。
removechild() :
<body>
<p id="cssrain">
<p id="a">a </p>
<p id="b">b </p>
<p id="c">c </p>
</p>
</body>
<script>
var msg = document.getelementbyid(cssrain);
var b = document.getelementbyid(b);
msg.removechild(b);
</script>
如果不知道要删除的节点的父节点是什么?可以使用parentnode属性。
比如:
<body>
<p id="cssrain">
<p id="a">a </p>
<p id="b">b </p>
<p id="c">c </p>
</p>
</body>
<script>
var b = document.getelementbyid(b);
var c = b.parentnode;
c.removechild(b);
</script>
注意: 你如果想把某个节点从一处移动到另一个地方,不必使用removechild()。
可以使用前面的 appendchild()和insertbefore(),他们都会自动先删除节点,然后移动到你指定的地方。、
5, 替换节点。
element.repalcechild( newnode , oldnode );
oldnode必须是element的一个子节点。
<body>
<p id="cssrain">
<p id="a">a </p>
<p id="b">b </p>
<p id="c">c </p>
</p>
</body>
<script>
var cssrain = document.getelementbyid(cssrain);
var msg = document.getelementbyid(b);
var para = document.createelement(p);
cssrain.replacechild( para , msg );
</script>
6, 设置/获取属性节点。
setattribute();//设置
例子:
var a = document.createelement(“p”);
a.setattribute(“title”,”my demo”);
不管以前有没有title属性,以后的值是 my demo。
getattribute();//获取
例子:
var a =document.getelementbyid(“cssrain”);
var b = a.getattribute(“title”);
获取的时候,如果属性不存在,则返回空,注意ie和ff返回不同,可以看我以前的例子。
返回虽然不同,但是可以用一个方法来判断。
if(a.getattribute(“title”) ){ }
7, 查找节点。
getelementbyid();
返回一个对象, 对象拥有 nodename , nodetype , parentnode , childnodes 等属性。
getelementsbytagname() 查找标签名的所有元素。
返回一个集合,可以用循环取出每个对象,对象拥有 nodename , nodetype , parentnode , childnodes 等属性。
例子:
var ps = document.getelementsbytagname(“p”);
for(var i=0 ; i< ps.length ; i++){
ps[i].setattribute(“title”,”hello”);
//也可以使用: ps.item(i).setattribute(title,hello);
}
haschildnodes:
由名字就可以知道,是判断元素是否有子节点。
返回boolean类型。
文本节点和属性节点不可能有子节点,所以他们的haschildnodes 永远返回false;
haschildnodes经常跟 childnodes 一起使用。
比如:
<body>
<p id="cssrain">
<p id="a">a </p>
<p id="b">b </p>
<p id="c">c </p>
</p>
</body>
<script>
var ps = document.getelementbyid(cssrain)
if(ps.haschildnodes){
alert( ps.childnodes.length );
}
</script>
8, dom属性:
nodename属性 : 节点的名字。
如果节点是元素节点,那么返回这个元素的名字。此时,相当于tagname属性。
比如:
<p>aaaa</p> : 则返回 p ;
如果是属性节点,nodename将返回这个属性的名字。
如果是文本节点,nodename将返回一个#text的字符串。
另外我要说的是: nodename属性是一个只读属性,不能进行设置.(写)
nodetype属性 : 返回一个整数,代表这个节点的类型。
我们常用的3中类型:
nodetype == 1 : 元素节点
nodetype == 2 : 属性节点
nodetype == 3 : 文本节点
如果想记住的话,上面的顺序我们可以看做是从 前到后。
比如: <p title="cssrain" >test</p> 从前往后读: 你会发现 先是元素节点,然后是属性节点,最后是文本节点,这样你就很容易记住了 nodetype分别代表什么类型了。
nodetype属性经常跟 if 配合使用,以确保不会在错误的节点类型上 执行错误的操作。
比如:
function cs_demo(mynode){
if(mynode.nodetype == 1){
mynode.setattribute(title,demo);
}
}
代码解释: 先检查mynode的nodetype属性,以确保它所代表的节点确实是 一个元素节点。
和nodename属性一样,他也是只读属性,不能进行设置.(写)。
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().
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 属性是一个只读属性。
好了,dom的常用属性和方法说到这里,了解这些方法的使用,
相信大家的dom编程技术会有很大的提高。