国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > 綜合 > 正文

文檔對象模型(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);
}
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 衡水市| 玉山县| 体育| 宣汉县| 通辽市| 同德县| 工布江达县| 海淀区| 南召县| 盖州市| 沾化县| 从江县| 灵石县| 开封市| 台前县| 大悟县| 醴陵市| 荣成市| 金华市| 甘谷县| 苍山县| 两当县| 石城县| 西畴县| 铜川市| 青河县| 高安市| 陵水| 夏邑县| 仙游县| 女性| 砀山县| 澳门| 潜山县| 社会| 洪泽县| 萝北县| 保山市| 拜泉县| 临桂县| 镇宁|