推薦閱讀:JavaScript駕馭網頁-DOM
DOM是種符合萬維網標准的HTML操縱方式,它能比innerHTML特性達成更多操控功能
這裡有HTML代碼與CSS代碼
<!doctype html> <html> <head> <meta charset="utf-8"> <title>無標題文檔</title> <style type="text/css"> span.class1{ background-color:#DDDDDD; } span.class2{ background-color:#221717; } </style> </head> <body> <span id="span1" class="class1"> Start Game </span> <span id="span2" class="class2"> Start Game </span> </body> </html>
借由改變節點的整份樣式類,className節點特性達成戲劇性的樣式變化
DOM透過節點屬性的className特性,提供對元素樣式類的訪問
alert(document.getElementById(“span1”).className);
通過更改CSS樣式類的名稱,完成對元素外觀的轉變
document.getElementById(“span1”).className=”class2”;//將span1的樣式換成span2的樣式
同理,我們也可以在這裡用onmouseover()與onmouseout()事件對元素的樣式加以控制
<span id="span1" class="class1" onMouseOver="this.className='class2'" onMouseOut="this.className='class1'">
雖然這種效果一般用CSS來加以控制,不過,這裡只注重對這些工具的應用,大家觸類旁通即可
CSS樣式類與Javascript類完全無關——它們是完全不同的東西
借由訪問節點的單一樣式特性,style節點特性達成少量樣式變化
節點的Style特性提供對單一樣式特性的訪問
<span id="span1" class="class1" onMouseOver="this.className='class2'" onMouseOut="this.className='class1'" style=" visibility:hidden">
style=” visibility:hidden”指示元素隱藏
網頁元素可以利用元素對象的visibility 樣式特性做動態的顯示或隱藏(display:none/display:block 同樣可以完成對元素的隱藏與顯示)
DOM能隨意創建任何HTML元素,當然包括文本段落
document.createElement()用於創建一個HTML標簽,參數是標簽名
document.createElement(“p”)創建一個p標簽
另:document.createTextNode()用於創建文本段落,參數是文本內容
var pElem=document.createElement(“p”);//創建一個P標簽
pElem.appendChild(document.createTextNode(“Hello WeAreZero!”));//為P標簽添加子元素 文本
document.getElementById(“span1”).appendChild(pElem);//將P標簽以及其子元素添加到span1標簽下
附錄:
利用document對象的createElement()方法,能夠創建任何HTML元素
若需新增元素的文本內容,必須創建一個文本內容子元素,並附加至元素下
借由小心地新增與移除DOM樹上的節點,網頁可以隨意拆解與重組
JavaScript駕馭網頁-CSS與DOM的介紹就到這裡,希望對大家有所幫助!