透過 HTML DOM,可存取 JavaScript HTML 文件的所有元素。
HTML DOM (文檔物件模型)
當網頁被載入時,瀏覽器會建立頁面的文檔物件模型(Document Object Model)。
HTML DOM 模型被建構為物件的樹:
透過可程式化的物件模型,JavaScript 獲得了足夠的能力來建立動態的 HTML。
找 HTML 元素
通常,透過 JavaScript,您需要操作 HTML 元素。
為了做到這件事情,您必須先找到該元素。有三種方法來做這件事:
在 DOM 中尋找 HTML 元素的最簡單的方法,是透過使用元素的 id。
本例查找 id="intro" 元素:
實例
var x=document.getElementById("intro");
如果找到該元素,則該方法將以物件(在 x 中)的形式傳回該元素。
如果未找到該元素,則 x 將包含 null。
透過標籤名稱找出 HTML 元素
本範例找出 id="main" 的元素,然後找出 id="main" 元素中的所有
元素:
實例
var x=document.getElementById("main"); var y=x.getElementsByTagName("p");
透過類別名稱找出 HTML 元素
本範例透過 getElementsByClassName 函數來找出 class="intro" 的元素:
實例
var x=document.getElementsByClassName("intro");
改變 HTML
HTML DOM 允許 JavaScript 改變 HTML 元素的內容。
改變 HTML 輸出流
JavaScript 能夠建立動態的 HTML 內容:
今天的日期是: Wed Oct 21 2015 14:43:25 GMT 0800 (中國標準時間)
在 JavaScript 中,document.write() 可用來直接向 HTML 輸出流寫內容。
實例
<!DOCTYPE html> <html> <body> <script> document.write(Date()); </script> </body> </html>
lamp 絕對不要在文件載入完成之後使用 document.write()。這會覆蓋該文件。
改變 HTML 內容
修改 HTML 內容的最簡單的方法時使用 innerHTML 屬性。
如需改變 HTML 元素的內容,請使用這個語法:
document.getElementById(id).innerHTML=new HTML
本例改變了
元素的內容:
實例
<html> <body> <p id="p1">Hello World!</p> <script> document.getElementById("p1").innerHTML="New text!"; </script> </body> </html>
本例改變了
<!DOCTYPE html> <html> <body> <h1 id="header">Old Header</h1> <script> var element=document.getElementById("header"); element.innerHTML="New Header"; </script> </body> </html>
實例解說:
改變 HTML 屬性
如需改變 HTML 元素的屬性,請使用這個語法:
document.getElementById(id).attribute=new value
本例改變了 元素的 src 屬性:
實例
<!DOCTYPE html> <html> <body> <img id="image" src="smiley.gif" alt="詳解JavaScript操作HTML DOM的基本方式_基礎知識" > <script> document.getElementById("image").src="landscape.jpg"; </script> </body> </html>
實例解說: