使用 JavaScript getHTML() 方法來取得 Dom 的 HTML

以往我們要透過 JavaScript 取得網頁的 HTML 會使用 innerHTML() 的方法,不過這個方法會有一些安全性的問題,而近來 JavaScript 為 Element 介面新增了一個實用的方法——getHTML()。這個方法提供了一種新的方式來獲取元素的 HTML 內容,與 innerHTML 類似,但提供了更強大的功能,例如支援 Shadow DOM 的序列化。

Element.getHTML() 的語法

let htmlString = element.getHTML(options);

參數:

  • options(選擇):一個物件,包含以下屬性:

    • serializableShadowRoots(布林值):指定是否包含可序列化的 Shadow DOM,預設為 false

    • shadowRoots(陣列):指定要序列化的 ShadowRoot 物件,即使它們是封閉的 Shadow DOM。

回傳值:

  • getHTML() 方法會回傳該元素的 HTML 字串。

序列化 Shadow DOM

對於具有 Shadow DOM 的自訂元件,getHTML() 允許開發者選擇是否序列化 Shadow DOM。

// 假設有一個自訂元素
let customElement = document.querySelector("my-custom-element");

// 獲取包含 Shadow DOM 的 HTML
let htmlString = customElement.getHTML({ serializableShadowRoots: true });
console.log(htmlString);

此範例中,若 my-custom-element 內部包含 Shadow DOM,則 getHTML() 會將其內容一併序列化。

getHTML() vs. innerHTML

方法 支援 Shadow DOM 讀取方式
innerHTML 只讀取標準 DOM 的內部 HTML
getHTML() 是(可選) 可讀取標準 DOM 及可序列化的 Shadow DOM

這意味著當處理 Web Components 或有 Shadow DOM 的元素時,getHTML() 是更好的選擇。

 

相容性與未來展望

目前 getHTML() 仍屬於較新的 API,因此在舊版瀏覽器可能無法支援。開發者應在使用前確認目標環境的相容性,或使用 innerHTML 作為回退方案。

let htmlString = element.getHTML ? element.getHTML() : element.innerHTML;

隨著 Web 技術的發展,getHTML() 有望成為未來 JavaScript 標準方法的一部分,為開發者提供更靈活的 HTML 讀取方式。

總結

  • getHTML() 是 JavaScript Element 介面中的新方法。

  • 提供比 innerHTML 更強大的功能,特別是對於 Shadow DOM。

  • 目前支援度尚未普及,開發時應考慮相容性。

  • 是未來 HTML 序列化的理想選擇。

對於希望更靈活處理 HTML 內容的開發者來說,getHTML() 無疑是一個值得關注的 API。

課程推薦

AI工作術全面學習實戰營:6 堂精選課程,學會最好用 AI 工具,翻轉你的人生

AI工作術全面學習實戰營:6 堂精選課程,學會最好用 AI 工具,翻轉你的人生

《PChome雜誌》攜手 5 位在 AI 領域的專業講師,打造上述 6 堂實用課程,教你學會時下最好用的 AI 工具,導入生成式 AI 來產製工作內容,改造並升級你的工作流程。

輸入折扣碼 ZERO2024 還可以額外獲得 NT$400 優惠喔。

HTML與SEO實戰應用—並以ChatGPT助力提升網站品質與流量

HTML與SEO實戰應用—並以ChatGPT助力提升網站品質與流量

本課程專為希望深入了解 HTML 並有效結合 SEO 策略的學員設計。我們將重點放在 HTML 的深度學習與應用上,同時穿插介紹如何透過搜索引擎優化提升網站能見度。透過即時互動式的直播教學,加上 ChatGPT 的輔助,您將學習到如何建立一個結構優良、美觀且符合 SEO 標準的網站。這不僅會提升網站的用戶體驗,還會大幅提高網站的搜索引擎排名,進而增加訪客流量和潛在客戶。
用AI強化職場競爭力 ChatGPT、Midjourney從入門到精通

用AI強化職場競爭力 ChatGPT、Midjourney從入門到精通

在快速變遷的職場中,提升競爭力成為關鍵。透過引領潮流的AI技術,ChatGPT和Midjourney將助您勇攀高峰。無論您是AI新手還是專家,這個課程將引導您從入門到精通,解密AI的奧秘,並學習如何運用於職場。
GitHub Copilot AI 程式碼編輯工具應用實務班

GitHub Copilot AI 程式碼編輯工具應用實務班

讓學員瞭解有效地使用該工具來加速開發流程、提高程式碼品質和生產力。課程重點放在以 JavaScript 程式語言為例,介紹 Copilot 的基本原理、使用方法和最佳實踐。

輸入折扣碼 TC1456JA 還可以額外獲得 NT$500 優惠喔。

ChatGPT X Clipchamp AI 生成影片、配音與字幕應用實戰班

ChatGPT X Clipchamp AI 生成影片、配音與字幕應用實戰班

掌握Clipchamp AI的操作技巧,靈活運用Clipchamp AI進行影片編輯和創作,實現創意表達和傳播目的。

輸入折扣碼 TC1451JAN 還可以額外獲得 NT$500 優惠喔。

如何串接多種數位工具資訊?Looker Studio 資料視覺化實戰班|GoogleAds x FB廣告 x GA流量數據

如何串接多種數位工具資訊?Looker Studio 資料視覺化實戰班|GoogleAds x FB廣告 x GA流量數據

Looker Studio除了可協助使用者監控網站流量、廣告成效、選擇匯入資源的管道之外,還可以將數據資料多平台整合、數據報表即時更新、數據範本可重複套用的效益,透過自動化系統,將數據全部匯入同一個報表平台,是企業不可或缺的重要工具。

輸入折扣碼 TC1270JIA 還可以額外獲得 NT$500 優惠喔。

和我們交流

加入我們的社群,裡面會有一些技術的內容、有趣的技術梗,以及職缺的分享,歡迎和我們一起討論。