javascript html dom,javascript 操作 HTML DOM
主要概述一些有用的基礎的DOM的方法以及怎樣用使用javascript使用它們。
可以實現比如動態地新建控制移動HTML元素。
Document 對象的常用方法
1、getElementById(id)
通過元素的ID訪問元素,這是DOM一個基礎的訪問頁面元素的方法,我們要經常用到它.
例如下面的例子,我們可以同DIV的ID迅速的訪問到它,而不必通過DOM層層遍歷,
h
Just for testing;
Just for testing;
var div=document.getElementById(‘divid’);
alert(div.nodeName);
注意使用這個函數時如果元素的ID不是唯一的,那么會獲得第一個符合條件的元素。
在IE6中如果input、checkbox,radio. 等元素name匹配指定的ID,也會被訪問到
例如下面的例子中,獲得的元素是input:
Just for testing;
var div=document.getElementById('divid');
alert(div.nodeName);
2、getElementsByName(name)
返回名字是name的元素數組,在IE6中元素ID匹配這個名字的話,這個元素也將包括在內,而且getElementsByName()僅用于象input,radio,checkbox等元素對象。
象下面例子中georges數組的長度應該是0。
ffvar georges=document.getElementsByName("george");
alert(georges.length);
3、getElementsByTagName(tagname)
getElementByTagName可以用于DOCUMENT也可以用元素。getElementsByTagName返回具有指定tagname的子元素列表(數組)。你可以遍歷這個數組獲得每一個單獨的子元素。當處理很大的DOM結構,使用這種方法可以很容易的所有縮小范圍。
function start() {
// 獲得所有tagName是body的元素(當然每個頁面只有一個)
myDocumentElements=document.getElementsByTagName("body");
myBody=myDocumentElements.item(0);
// 獲得body子元素種的所有P元素
myBodyElements=myBody.getElementsByTagName("p");
// 獲得第二個P元素
myP=myBodyElements.item(1);
//顯示這個元素的文本
alert(myP.firstChild.nodeValue);
}
hi
hello
DOM Element 常用方法
1、appendChild(node)
向當前節點對象的追加節點。經常用于給頁面動態的添加內容。
例如下面給div添加一個文本節點:
var newdiv=document.createElement("div")
var newtext=document.createTextNode("A new div")
newdiv.appendChild(newtext)
document.getElementById("test").appendChild(newdiv)
上面的例子中給DIV添加文本,也可以用newdiv.innerHTML=”A new div”實現,
不過innerHTML不屬于DOM
2、removeChild(childreference)
移除當前節點的子節點,返回被移除的節點。這個被移除的節點可以被插入document樹中別的地方
A childvar childnode=document.getElementById("child")
var removednode=document.getElementById("father").removeChild(childnode)
3、cloneNode(deepBoolean)
復制并返回當前節點的復制節點,這個復制得到的節點是一個孤立的節點,不在document樹中。復制原來節點的屬性值,包括ID屬性,所以在把這個新節點加到document之前,一定要修改ID屬性,以便使它保持唯一。當然如果ID的唯一性不重要可以不做處理。
這個方法支持一個布爾參數,當deepBoolean設置true時,復制 當前節點的所有子節點,包括該節點內的文本。
11111
p=document.getElementById("mypara")
pclone = p.cloneNode(true);
p.parentNode.appendChild(pclone);
spanvar oldel=document.getElementById("innerspan");
var newel=document.createElement("p");
var text=document.createTextNode(“ppppp”);
newel.appendChild(text);
document.getElementById("adiv").replaceChild(newel, oldel);
5、insertBefore(newElement, targetElement)
給當前節點插入一個新節點,如果targetElement被設置為null,那新節點被當作最后一個子節點插入,否則那新節點應該被插入targetElement之前的最近位置。
熊掌我所欲也!
var lovespan=document.getElementById("lovespan")
var newspan=document.createElement("span")
var newspanref=document.body.insertBefore(newspan, lovespan)
newspanref.innerHTML="魚與";
function wow() {
alert("我好象沒有點鼠標啊");
}
hhhvar div = document.getElementById("test");
div.click();
DOM Element的屬性:(下面是常用的。IE5.0以上,mozllia都支持的)
1、childeNodes? 返回所有子節點對象,
例如
| 一個和尚有水喝。 |
| 兩個和尚挑水喝。 |
| 三個和尚沒水喝。 |
var msg=””
var mylist=document.getElementById("mylist")
for (i=0; i
var tr=mylist.childNodes[i];
for(j=0;j
var td=tr.childNodes[j];
msg+=td.innerText;
}
}
alert(msg);
2、innerHTML
這是一個事實上的標準,不屬于w3c DOM,但是幾乎所有支持DOM的瀏覽器,都支持這個屬性。通過這個屬性我們很容易修改一個元素的HTML。
新人類,什么?!
window.οnlοad=function(){
document.getElementsByTagName("p")[0].innerHTML="新新人類,什么?!"
}
3、style
返回一個元素的style對象的引用,通過它我們可以獲得并修改每個單獨的樣式。
例如下面的腳本可以修改一個元素的背景色
document.getElementById("test").style.backgroundColor="yellow"
4、firstChild??? 返回第一個子節點
5、lastChild???? 返回最后一個子節點
6、parentNode?? 返回父節點的對象。
7、nextSibling?? 返回下一個兄弟節點的對象
8、previousSibling 返回前一個兄弟節點的對象
9、nodeName 返回節點的HTML標記名稱,使用英文的大寫字母,如P, FONT
例如
dddif (document.getElementById("test").nodeName=="DIV")
alert("This is a DIV");
第一個例子:
使用DOM1.0?? 的javascript動態地創建一個HTML table。
Sample codefunction start() {
//獲得body的引用
var mybody=document.getElementsByTagName("body").item(0);
//創建一個
元素mytable = document.createElement("TABLE");
//創建一個
元素mytablebody = document.createElement("TBODY");
// 創建行列
for(j=0;j<3;j++) {
//創建一個
元素mycurrent_row=document.createElement("TR");
for(i=0;i<3;i++) {
//創建一個
元素mycurrent_cell=document.createElement("TD");
//創建一個文本元素
currenttext=document.createTextNode("cell is row "+j+", column "+i);
//把新的文本元素添加到單元TD上
mycurrent_cell.appendChild(currenttext);
// appends the cell TD into the row TR
//把單元TD添加到行TR上
mycurrent_row.appendChild(mycurrent_cell);
}
//把行TR添加到TBODY上
mytablebody.appendChild(mycurrent_row);
}
// 把 TBODY 添加到 TABLE
mytable.appendChild(mytablebody);
// 把 TABLE 添加到 BODY
mybody.appendChild(mytable);
// 把mytable的border 屬性設置為2
mytable.setAttribute("border","2");
}
總結
以上是生活随笔為你收集整理的javascript html dom,javascript 操作 HTML DOM的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 个体户个税怎么申报 个体户个税怎样申报
- 下一篇: c ajax 上传图片,ajax +N