摘要:對象提供了屬性和方法實現定位頁面元素功能,這也是的標準規范中對象的主要應用之一。是返回值,表示定位元素的集合,是一個集合。定位匹配選擇器的第一個元素。方法定位頁面元素所返回的集合就是靜態集合。
Document 對象提供了屬性和方法實現定位頁面元素功能,這也是 DOM 的標準規范中 Document 對象的主要應用之一。
定位頁面元素方法目前 Document 對象提供實現定位頁面元素的方法具有如下幾種:
getElementById()方法:通過頁面元素的 id 屬性值定位元素。
getElementsByName()方法:通過頁面元素的 name 屬性值定位元素。
getElementsByTagName()方法:通過頁面元素的元素名定位元素。
getElementsByClassName()方法:通過頁面元素的 class 屬性值定位元素。
querySelector()方法:通過 CSS 選擇器定位第一個匹配的元素。
querySelectorAll()方法:通過 CSS 選擇器定位所有匹配的元素。
接下來,我們就一一進行學習。
通過元素的 ID 屬性值定位元素HTML 頁面元素的 id 屬性的特點是唯一、不可重復的,所以通過這種方式定位的 HTML 頁面元素也是唯一的。
其語法格式如下:
element = document.getElementById(id);
在上述語法中,id 是參數,表示所要定位元素的 id 屬性值,是一個大小寫敏感的字符串。element 是返回值,表示定位的元素,是一個 Element 對象。
值得注意的是: 如果 HTML 頁面中不存在具有該 id 屬性值的元素,則返回 null。
下面是使用 getElementById() 方法的示例代碼:
var btn = document.getElementById("btn"); // 獲取定位元素的 class 屬性值 var className = btn.className; // 添加 animate 動畫樣式 className += " animate"; // 將新的 class 屬性值設置 btn.className = className;
上述代碼通過 getElementById() 方法定位 HTML 頁面中 id 屬性值為 btn 的元素,并為其元素的 class 屬性添加 animate 樣式。
通過元素的 name 屬性值定位元素完整示例代碼請點擊右邊的鏈接: getElementById()方法完整示例代碼
其語法格式如下:
elements = document.getElementsByName(name);
在上述語法中,name 是參數,表示所要定位元素的 name 屬性值,是一個大小寫敏感的字符串。elements 是返回值,表示定位元素的集合,是一個 NodeList 集合。
下面是使用 getElementsByName() 方法的示例代碼:
var elems = document.getElementsByName("btn"); // 循環遍歷所有元素 for (var i=0; i上述代碼通過 getElementsByName() 方法定位 HTML 頁面中 name 屬性值為 btn 的元素,并遍歷所有得到的元素,為其元素的 class 屬性添加 animate 樣式。
通過元素的元素名定位元素完整示例代碼請點擊右邊的鏈接: getElementsByName()方法完整示例代碼
其語法格式如下:
elements = document.getElementsByTagName(name);在上述語法中,name 是參數,表示所要定位元素的元素名,符號”*”表示所有元素。elements 是返回值,表示定位元素的集合,是一個 NodeList 集合。
下面是使用 getElementsByTagName() 方法的示例代碼:
var elems = document.getElementsByTagName("button"); // 循環遍歷所有元素 for (var i=0; i上述代碼通過 getElementsByTagName() 方法定位 HTML 頁面中元素名為 button 的元素,并遍歷所有得到的元素,為其元素的 class 屬性添加 animate 樣式。
通過元素的 class 屬性值定位元素完整示例代碼請點擊右邊的鏈接: getElementsByTagName()方法完整示例代碼
其語法格式如下:
elements = document.getElementsByClassName(names);在上述語法中,names 是參數,表示所要定位元素的 class 屬性值列表,class 名稱通過空格分隔。
值得注意的是: names 參數可以是一個樣式屬性名稱,也可以是多個樣式屬性名稱。
elements 是返回值,表示定位元素的集合,是一個 NodeList 集合。
下面是使用 getElementsByClassName() 方法的示例代碼:
var elems = document.getElementsByClassName("btn"); // 循環遍歷所有元素 for (var i=0; i上述代碼通過 getElementsByClassName() 方法定位 HTML 頁面中 class 屬性值為 btn 的元素,并遍歷所有得到的元素,為其元素的 class 屬性添加 animate 樣式。
兼容 IE 8 及之前版本的瀏覽器完整示例代碼請點擊右邊的鏈接: getElementsByClassName()方法完整示例代碼
getElementsByClassName() 方法只支持 IE 9 版本及之后版本的瀏覽器。也就是說,該方法并不支持 IE 8 及之前版本的瀏覽器。
下圖是不同瀏覽器的不同版本對 getElementsByClassName() 方法的支持情況:
由于國內的生產環境中,依舊存在使用 IE 8 及之前版本瀏覽器的情況。所以,我們需要自定義 getElementsByClassName() 方法解決瀏覽器的兼容問題。
function getElementsByClassName(element, names) { }上述自定義兼容方法接受兩個參數,element 參數表示調用 getElementsByClassName() 方法的對象(目前為 Document 對象),names 參數表示所要定位元素的 class 屬性值列表。
function getElementsByClassName(element, names) { // 檢測 getElementsByClassName() 是否可用 if (element.getElementsByClassName) { // 優先使用 W3C 規范 return element.getElementsByClassName(names); }else { // 人為解決 IE 8 之前版本不兼容問題 } }這里我們要優先使用 W3C 規范的方法。所以,需要先判斷當前瀏覽器環境是否存在 getElementsByClassName() 方法。
如果存在,就使用原本的 getElementsByClassName() 方法。如果不存在,就使用自定義代碼來實現。
function getElementsByClassName(element, names) { // 檢測 getElementsByClassName() 是否可用 if (element.getElementsByClassName) { // 優先使用 W3C 規范 return element.getElementsByClassName(names); }else { // 人為解決 IE 8 之前版本不兼容問題 // 獲取所有后代元素節點 var elements = element.getElementsByTagName("*"); // 定義空數組 var result = []; var element, classNameStr, flag; // 將樣式名稱改為數組類型 names = names.split(" "); // 循環遍歷所有元素節點 for (var i=0; element = elements[i]; i++) { // 獲取每個元素節點的樣式名稱 classNameStr = " " + element.className + " "; // 開啟開關 flag = true; // 循環遍歷所有的樣式名稱 for (var j=0, name; name = names[j]; j++) { // 判斷當前元素節點的樣式名稱中是否包含指定的樣式名稱 if (classNameStr.indexOf(" " + name + " ") == -1){ // 如果不包含,則關閉開關,并且結束循環 flag = false; break; } } // 判斷當前元素節點是否包含指定樣式名稱 if (flag) { // 如果包含,則將當前元素節點添加到數組中 result.push(element); } } // 返回數組(所有包含指定樣式名稱的元素節點) return result; } }通過 CSS 選擇器定位元素CSS 中的選擇器可以很便利地定位 HTML 頁面元素,DOM 的標準規范中也提供類似的方法。
querySelector(): 定位匹配選擇器的第一個元素。
querySelectorAll(): 定位匹配選擇器的所有元素。
querySelector() 方法其語法格式如下:
element = document.querySelector(selectors);在上述語法中,selectors 是參數,表示選擇器,可以包含一個或多個 CSS 選擇器,多個則以逗號分隔。element 是返回值,表示定位元素的集合,匹配的第一個元素。
下面是使用 querySelector() 方法的示例代碼:
var btn = document.querySelector(’#btn"); // 獲取定位元素的 class 屬性值 var className = btn.className; // 添加 animate 動畫樣式 className += " animate"; // 將新的 class 屬性值設置 btn.className = className;上述代碼通過 querySelector() 方法定位 HTML 頁面中 id 屬性值為 btn 的元素,并為其元素的 class 屬性添加 animate 樣式。
querySelectorAll() 方法完整示例代碼請點擊右邊的鏈接: querySelector()方法完整示例代碼
其語法格式如下:
elements = document.querySelectorAll(selectors);在上述語法中,selectors 是參數,表示選擇器,可以包含一個或多個 CSS 選擇器,多個則以逗號分隔。elements 是返回值,表示定位元素的集合,是一個 NodeList 集合。
下面是使用 querySelectorAll() 方法的示例代碼:
var elems = document.querySelectorAll("button"); // 循環遍歷所有元素 for (var i=0; i上述代碼通過 querySelectorAll() 方法定位 HTML 頁面中元素名為 button 的元素,并遍歷所有得到的元素,為其元素的 class 屬性添加 animate 樣式。
節點集合 NodeList完整示例代碼請點擊右邊的鏈接: querySelectorAll()方法完整示例代碼
NodeList 是一組元素節點的集合,每個節點具有相應的索引值(從 0 開始的數字,類似于數組)。
元素節點在 NodeList 集合中存儲的順序與它們在 HTML 頁面中的順序保持一致。
NodeList 的屬性 length 表示 NodeList 對象中包含的節點個數。方法 item(index) 表示返回 NodeList 對象中指定索引的節點。如果索引值越界,則返回 null。
NodeList 集合分為兩種: 動態 NodeList 和靜態 NodeList。
動態的 NodeList 集合所謂動態的 NodeList 集合,就是如果文檔中的節點樹發生變化,則已經存在的 NodeList 對象也可能會變化。
以下幾種定位 HTML 頁面元素的方法返回的都是動態的 NodeList 集合。
getElementsByName()方法:通過頁面元素的 name 屬性值定位元素。
getElementsByTagName()方法:通過頁面元素的元素名定位元素。
getElementsByClassName()方法:通過頁面元素的 class 屬性值定位元素。
我們可以通過以下示例代碼,體驗動態 NodeList 集合的特點:
var elems = document.getElementsByTagName("button"); console.log(elems.length);// 輸出 3 // 添加一個新的button按鈕 var btn = document.createElement("button"); btn.setAttribute("class","button"); var text = document.createTextNode("New Button"); btn.appendChild(text); var div = document.getElementsByClassName("button-group")[0]; div.appendChild(btn); console.log(elems.length);// 輸出 4上述代碼通過 getElementsByTagName() 方法定位 HTML 頁面中所有的 button 元素,測試打印 button 元素的個數是 3 個。
然后,我們創建一個新的 button 元素,并且將其添加到 HTML 頁面中,再測試打印 button 元素的個數是 4 個。
靜態 NodeList 集合值得注意的是: 我們在第二次測試打印 button 元素的個數時,并沒有重新定位 HTML 頁面中的 button 元素。
完整示例代碼請點擊右邊的鏈接: 動態 NodeList 集合完整示例代碼
所謂靜態 NodeList 集合,就是對文檔對象模型的任何改動都不會影響集合的內容。
querySelectorAll() 方法定位 HTML 頁面元素所返回的 NodeList 集合就是靜態 NodeList 集合。
我們可以通過以下示例代碼,體驗靜態 NodeList 集合的特點:
var elems = document.querySelectorAll("button"); console.log(elems.length);// 輸出 3 // 添加一個新的button按鈕 var btn = document.createElement("button"); btn.setAttribute("class","button"); var text = document.createTextNode("New Button"); btn.appendChild(text); var div = document.getElementsByClassName("button-group")[0]; div.appendChild(btn); console.log(elems.length);// 輸出 3上述代碼通過 querySelectorAll() 方法定位 HTML 頁面中所有的 button 元素,測試打印 button 元素的個數是 3 個。
然后,我們創建一個新的 button 元素,并且將其添加到 HTML 頁面中,再測試打印 button 元素的個數依舊是 3 個。
定位頁面元素屬性完整示例代碼請點擊右邊的鏈接: 靜態 NodeList 集合完整示例代碼
Document 對象也提供了一些屬性,來定位 HTML 頁面中一些比較特殊的元素。
documentElement:獲取 HTML 頁面中的 元素。
head:獲取 HTML 頁面中的 元素。
title:獲取 HTML 頁面中的
元素。 body:獲取 HTML 頁面中的 元素。
images:獲取 HTML 頁面中的所有 元素。
我們可以定義一個包含以上元素的 HTML 頁面,然后通過以下示例代碼進行測試:
console.log(document.documentElement); console.log(document.head); console.log(document.body); console.log(document.title); console.log(document.links); console.log(document.images);本教程免費開源,任何人都可以免費學習、分享,甚至可以進行修改。但需要注明作者及來源,并且不能用于商業。
本教程采用知識共享署名-非商業性使用-禁止演繹 4.0 國際許可協議進行許可。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/84063.html
摘要:對象提供了屬性和方法實現定位頁面元素功能。定位匹配選擇器的第一個元素。是返回值,表示定位元素的集合,是一個集合。下面是使用方法的示例代碼循環遍歷所有元素上述代碼通過方法定位頁面中元素名為的元素,并遍歷所有得到的元素,為其元素的屬性添加樣式。 Element 對象提供了屬性和方法實現定位頁面元素功能。該對象與 Document 對象提供的屬性和方法實現定位頁面元素功能的區別在于,Docu...
摘要:簡單來說,節點作為樹結構中的連接點,最終構成了完整的樹結構。節點樹結構通過節點概念,我們可以將原本的樹結構改成節點樹結構進行表示。節點之間的關系中的表示模型,也可以用來表示節點樹結構中節點之間的關系。值得注意的是和元素并不是兄弟關系。 DOM 樹結構 DOM 之所以可以訪問和更新 HTML 頁面中的內容、結構和樣式,是因為 DOM 將 HTML 頁面解析為一個 樹結構。 例如下面這段代...
摘要:回顧什么是內聯樣式所謂內聯樣式,就是通過頁面元素的屬性為當前元素定義樣式。對象提供的屬性和方法可以幫助我們獲取樣式的具體內容。遍歷對象由于對象具有屬性,返回該對象的屬性的數量。方法通過獲取的樣式屬性名,這種方式也可以通過方式進行替換。 回顧什么是內聯樣式 所謂內聯樣式,就是通過 HTML 頁面元素的 style 屬性為當前元素定義 CSS 樣式。 以下代碼示例,就是通過 style 屬...
摘要:系列教程是一套免費開源,任何人都可以免費學習分享,甚至可以進行修改。本文是這套系列教程的索引也就是目錄第一回介紹在最開始,我們先來了解是什么的作用,以及瀏覽器的支持是怎么樣的。 《EASYDOM》系列教程是一套免費、開源,任何人都可以免費學習、分享,甚至可以進行修改。但需要注明作者及來源,并且不能用于商業。 本文是這套系列教程的索引(也就是目錄): 第一回 DOM 介紹 在最開始,我...
摘要:對象的作用對象作為訪問和更新頁面內容的入口。這個結果充分地說明了對象在的標準規范中代表整個頁面。對象的繼承鏈對象是繼承于對象的。對象也是的標準規范中非常重要的對象之一,而對象又是繼承于對象。 Document 對象是 DOM 的標準規范中比較重要的對象之一。該對象提供了訪問和更新 HTML 頁面內容的屬性和方法。 Document 對象的作用 Document 對象作為 DOM 訪問和...
閱讀 3491·2021-11-18 10:07
閱讀 1589·2021-11-04 16:08
閱讀 1513·2021-11-02 14:43
閱讀 1088·2021-10-09 09:59
閱讀 844·2021-09-08 10:43
閱讀 1079·2021-09-07 09:59
閱讀 963·2019-12-27 11:56
閱讀 1012·2019-08-30 15:56