首頁 web前端 js教程 JavaScript中關於DOM的操作詳解

JavaScript中關於DOM的操作詳解

Aug 13, 2017 am 10:33 AM
javascript js 詳解

一、什麼是DOM

  JavaScript由ECMAScript、DOM和BOM三部分組成,其中DOM代表描述網頁內容的方法和接口,即文檔物件模型(Document Object Model)。在網頁上,組織頁面(或文件)的物件被組織在一個樹狀結構中,用來表示文件中物件的標準模型就稱為DOM,而樹狀結構就是我們常說的DOM樹。

  維基百科中介紹DOM更為準確:DOM是一種跨平台和語言非依賴性的應用程式編程接口,即處理現在的HTML,XHTML或XML文檔作為樹結構,其中每個節點是一個對象,每個節點表示該文件的一部分。

二、DOM節點

#1.節點的型別

  DOM樹是由許多不同類型的節點組成的,而這些節點類型都有一個nodeType值,我們可以透過nodeType值來判斷我們所獲得的或想要的是不是對應類型的節點。

節點類型 元素節點(標籤節點) 屬性節點 文字節點(空格、換行、文字) 註解節點 document節點
nodeType值 1 2 3 8 9

  除了透過nodeType值判斷型別以外我們也可以透過nodeName來檢視元素節點和屬性節點的節點名稱,還有使用nadeValue來檢視屬性節點的屬性值。

 

2.取得元素節點


document.getElementById(id);
document.getElementByTagName(tagname);
document.getElementByClassName(classname);
登入後複製

  通常想要在JavaScript中更改或使用HML中的元素節點時,都要先獲取才可以調用,那麼我們就是透過設定元素的Id屬性或Class屬性來獲取,或是使用標籤名獲取。但要注意的是getElementById()方法不能工作在XML中,在XML文件中,必須透過擁有id屬性來進行搜索,而此類型必須在 XML DTD 中進行聲明。

  取得完我們想要的節點後,我們還可以透過節點的關係來操作其他節點,這裡我們以p元素為初設元素節點來舉例。

  2.1 子節點


p.children();
p.childNodes();
登入後複製

 

#  取得p下面的子節點,而p.children()只能取得到是元素節點的子節點,而p.childNodes()會取得所有類型的子節點,也就是說會解析空白文字節點。

  2.2 父節點


p.parentNode();
p.offsetParent();
登入後複製
 

  取得p的父節點,p.offsetParent()取得的是具有定位屬性的祖先節點,即從父節點開始尋找,如果父節點沒有定位屬性,那麼再找父節點的父節點,直到找到有定位屬性的節點。

  2.3 兄弟節點



#
//下一个兄弟节点 p.nextElementSibling();
p.nextSibling();//上一个兄弟节点 p.previousElementSibling();
p.previousSibling();
登入後複製

   這裡有沒有Element很關鍵,跟取得子節點一樣,p.nextSibling()和p.previousSibling()會解析空白節點,會取得到p下面的空格或回車。

  2.4 首尾子節點


##

//获取p的第一个子节点p.firstElementChild();
p.firstChild();//获取p的最后一个子节点p.lastElementChild();
p.lastElementChild();
登入後複製

 


  區別同上。

 

3.節點運算


  我們除了可以在HTML中新增、刪除個修改節點,也可以在JavaScript中對節點進行操作。

  


3.1 建立節點


#

//创建节点/创建文本节点createElement();
createTextNode();
登入後複製

 

  創建文本節點一般用來在元素節點中添加內容,它創建的是靜態文本,不能像innerHTML一樣帶有HTML格式,所以creatTextNode()更安全,而innerText又有瀏覽器相容問題。

  3.2 新增節點  我們建立的節點不會自動加入到HTML裡,需要我們對建立的節點進行操作。

//向尾部添加子节点 appendChild(); 
//向目标节点之前添加insertBefore(newElement,targetElement);
登入後複製

  insertBefore()第二個參數是可選參數,如果不寫第二個參數那麼就預設向尾部添加,即等同於appendChild();

###  ######3.3 替換##################
//将旧节点换为新节点replaceChild(newElement,oldElement);
登入後複製
######  ###p.replaceChild(newElement,oldElement) ,這裡無論是新節點或舊節點,都必須是p的子節點。 ######  ######3.4 刪除###################
removeChild();
登入後複製
###  注意刪除的是子節點。 ######  ######3.5 複製/複製##################
//深复制或浅复制cloneNode(boolean);
登入後複製
###  當參數的布林值為true時為深複製,即會複製節點本身以及它以下的所有子節點。 ######  當參數的布林值為false時為淺複製,只會複製節點本身。 ######  ######3.6 判斷##################
hasChildNode();
登入後複製
###  判斷是否有子節點,傳回布林值。 ############  ######3.7 屬性########################
//获取节点属性getAttribute();//设置节点属性setAttribute();//删除节点属性removeAttribute();
登入後複製

  要注意的一点就是class属性不能通过setAttribute(); 设置。

三、DOM的优缺点

  DOM的优点主要表现在:易用性强,并且遍历简单,支持XPath,增强了易用性。

  DOM的缺点主要表现在:效率低,解析速度慢,内存占用量过高。

以上是JavaScript中關於DOM的操作詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

建議:優秀JS開源人臉偵測辨識項目 建議:優秀JS開源人臉偵測辨識項目 Apr 03, 2024 am 11:55 AM

人臉偵測辨識技術已經是一個比較成熟且應用廣泛的技術。而目前最廣泛的網路應用語言非JS莫屬,在Web前端實現人臉偵測辨識相比後端的人臉辨識有優勢也有弱勢。優點包括減少網路互動、即時識別,大大縮短了使用者等待時間,提高了使用者體驗;弱勢是:受到模型大小限制,其中準確率也有限。如何在web端使用js實現人臉偵測呢?為了實現Web端人臉識別,需要熟悉相關的程式語言和技術,如JavaScript、HTML、CSS、WebRTC等。同時也需要掌握相關的電腦視覺和人工智慧技術。值得注意的是,由於Web端的計

Win11管理員權限取得詳解 Win11管理員權限取得詳解 Mar 08, 2024 pm 03:06 PM

Windows作業系統是全球最受歡迎的作業系統之一,其新版本Win11備受矚目。在Win11系統中,管理員權限的取得是一個重要的操作,管理員權限可以讓使用者對系統進行更多的操作和設定。本文將詳細介紹在Win11系統中如何取得管理員權限,以及如何有效地管理權限。在Win11系統中,管理員權限分為本機管理員和網域管理員兩種。本機管理員是指具有對本機電腦的完全管理權限

Oracle SQL中的除法運算詳解 Oracle SQL中的除法運算詳解 Mar 10, 2024 am 09:51 AM

OracleSQL中的除法運算詳解在OracleSQL中,除法運算是一種常見且重要的數學運算運算,用來計算兩個數相除的結果。除法在資料庫查詢中經常用到,因此了解OracleSQL中的除法運算及其用法是資料庫開發人員必備的技能之一。本文將詳細討論OracleSQL中除法運算的相關知識,並提供具體的程式碼範例供讀者參考。一、OracleSQL中的除法運算

linux系統呼叫system()函數詳解 linux系統呼叫system()函數詳解 Feb 22, 2024 pm 08:21 PM

Linux系統呼叫system()函數詳解系統呼叫是Linux作業系統中非常重要的一部分,它提供了一種與系統核心互動的方式。其中,system()函數是常用的系統呼叫函數之一。本文將詳細介紹system()函數的使用方法,並提供對應的程式碼範例。系統呼叫的基本概念系統呼叫是使用者程式與作業系統核心互動的一種方式。使用者程式透過呼叫系統呼叫函數來請求作業系統

PHP模運算子的作用及用法詳解 PHP模運算子的作用及用法詳解 Mar 19, 2024 pm 04:33 PM

PHP中的模運算子(%)是用來取得兩個數值相除的餘數的。在本文中,我們將詳細討論模運算子的作用及用法,並提供具體的程式碼範例來幫助讀者更好地理解。 1.模運算子的作用在數學中,當我們將一個整數除以另一個整數時,就會得到一個商和一個餘數。例如,當我們將10除以3時,商數為3,餘數為1。模運算子就是用來取得這個餘數的。 2.模運算子的用法在PHP中,使用%符號來表示模

js和vue的關係 js和vue的關係 Mar 11, 2024 pm 05:21 PM

js和vue的關係:1、JS作為Web開發基石;2、Vue.js作為前端框架的崛起;3、JS與Vue的互補關係;4、JS與Vue的實踐應用。

Linux的curl指令詳解 Linux的curl指令詳解 Feb 21, 2024 pm 10:33 PM

Linux的curl命令詳解摘要:curl是一種強大的命令列工具,用於與伺服器進行資料通訊。本文將介紹curl指令的基本用法,並提供實際的程式碼範例,幫助讀者更好地理解和應用該指令。一、curl是什麼? curl是命令列工具,用於發送和接收各種網路請求。它支援多種協議,如HTTP、FTP、TELNET等,並提供了豐富的功能,如檔案上傳、檔案下載、資料傳輸、代

深入了解Promise.resolve() 深入了解Promise.resolve() Feb 18, 2024 pm 07:13 PM

Promise.resolve()詳解,需要具體程式碼範例Promise是JavaScript中一種用來處理非同步操作的機制。在實際開發中,常常需要處理一些需要依序執行的非同步任務,而Promise.resolve()方法就是用來傳回一個已經Fulfilled狀態的Promise物件。 Promise.resolve()是Promise類別的靜態方法,它接受一個

See all articles