文檔對象模型(DOM)的基本方法
2024-07-21 02:04:18
供稿:網(wǎng)友
一.直接引用結(jié)點
1.document.getelementbyid(id);
--在文檔里面通過id來找結(jié)點
2.document.getelementbytagname(tagname);
--返回一個數(shù)組,包含對這些結(jié)點的引用
--如:document.getelementbytagname("span");將返回所有類型為span的結(jié)點
二.間接引用結(jié)點
3.element.childnodes
--返回element的所有子結(jié)點,可以用element.childnodes[i]的方式來調(diào)用
--element.firstchild=element.childnodes[0];
--element.lastchild=element.childnodes[element.childnonts.length-1];
4.element.parentnode
--引用父結(jié)點
5.element.nextsibling; //引用下一個兄弟結(jié)點
element.previoussibling; //引用上一個兄弟結(jié)點
三.獲得結(jié)點信息
6.nodename屬性獲得結(jié)點名稱
--對于元素結(jié)點返回的是標(biāo)記名稱,如:<a herf><a>返回的是"a"
--對于屬性結(jié)點返回的是屬性名稱,如:class="test" 返回的是test
--對于文本結(jié)點返回的是文本的內(nèi)容
7.nodetype返回結(jié)點的類型
--元素結(jié)點返回1
--屬性結(jié)點返回2
--文本結(jié)點返回3
8.nodevalue返回結(jié)點的值
--元素結(jié)點返回null
--屬性結(jié)點返回undefined
--文本結(jié)點返回文本內(nèi)容
9.haschildnodes()判斷是否有子結(jié)點
10.tagname屬性返回元素的標(biāo)記名稱
--這個屬性只有元素結(jié)點才有,等同于元素結(jié)點的nodename屬性
四.處理屬性結(jié)點
11.每個屬性結(jié)點都是元素結(jié)點的一個屬性,可以通過(元素結(jié)點.屬性名稱)訪問
12.利用setattribute()方法給元素結(jié)點添加屬性
--elementnode.setattribute(attributename,attributevalue);
--attributename為屬性的名稱,attributevalue為屬性的值
13.使用getattribute()方法獲得屬性值
--elementnode.getattribute(attributename);
五.處理文本結(jié)點
14.innerhtml和innertext屬性,這兩個方法相信大家都很熟悉,不介紹了,值得注意的是無論是ie還是firefox都容易把空格、換行、制表符等當(dāng)成文本結(jié)點。所有一般通過element.childnodes[i]引用文本結(jié)點的時候,一般要處理:
<script language"javascript" type="text/javascript">
function cleanwhitespace(element)
{
for(var i=0; i<element.childnotes.length; i++)
{
var node = element.childnodes[i];
if(node.nodetype == 3 && !//s/.test(node.nodevalue))
{
node.parentnode.removechild(node);
}
}
}
</script>
六.改變文檔的層次結(jié)構(gòu)
15.document.createelement()方法創(chuàng)建元素結(jié)點
--如:document.createelement("span");
16.document.createtextnode()方法創(chuàng)建文本結(jié)點
--如:document.createtextnode(" "); //注:他不會通過html編碼,也就是說這里創(chuàng)建的不是空格,而是字符串
17.使用appendchild()方法添加結(jié)點
--parentelement.appendchild(childelement);
18.使用insertbefore()方法插入子節(jié)點
--parentnode.insertbefore(newnode,referencenode);
--newnode為插入的節(jié)點,referencenode為將插入的節(jié)點插入到這之前
19.使用replacechild方法取代子結(jié)點
--parentnode.replacechild(newnode,oldnode);
--注:oldnode必須是parentnode的子結(jié)點,
20.使用clonenode方法復(fù)制結(jié)點
--node.clonenode(includechildren);
--includechildren為bool,表示是否復(fù)制其子結(jié)點
21.使用removechild方法刪除子結(jié)點
--parentnode.removechild(childnode);
七.表格的操作
--注:ie中無法直接將一個完整的表格結(jié)點插入到文檔中
22.添加行和單元格
var _table=document.createelement("table"); //創(chuàng)建表
table.insertrow(i); //在table的第i行插入行
row.insertcell(i); //在row的第i個位置插入單元格
23.引用單元格對象
--table.rows[i].cells[i];
24.刪除行和單元格
--table.deleterow(index);
--row.deletecell(index);
25.交換兩行獲得兩個單元格的位置
node1.swapnode(node2);
--這個方法在firefox中將出錯
通用方法:
function swapnode(node1,node2)
{
var _parent=node1.parentnode;
var _t1=node1.nextsubling;
var _t2=node2.nextsubling;
if(_t1)parent.insertbefore(node2,_t1);
else _parent.appendchild(node2);
if(_t2)parent.insertbefore(node1,_t2);
else _parent.appendchild(node1);
}