首頁 >web前端 >js教程 >如何在 JavaScript 中偵測並回應 DOM 變更?

如何在 JavaScript 中偵測並回應 DOM 變更?

Linda Hamilton
Linda Hamilton原創
2024-12-15 01:54:09685瀏覽

How Can I Detect and Respond to DOM Changes in JavaScript?

偵測 DOM 變更

您可以使用各種方法來偵測文件物件模型 (DOM) 的變更。

1。 MutationObserver(現代瀏覽器)

const observer = new MutationObserver((mutations) => {
  // Process mutations here...
});

observer.observe(targetElement, { childList: true, subtree: true });

2.突變事件(已棄用,但仍支持)

targetElement.addEventListener('DOMNodeInserted', (event) => {
  // Node added
});

targetElement.addEventListener('DOMNodeRemoved', (event) => {
  // Node removed
});

範例:偵測輸入新增

如果您特別想在

const targetElement = document.getElementById('element-to-monitor');

const observer = new MutationObserver((mutations) => {
  mutations.forEach((mutation) => {
    if (mutation.type === 'childList' && mutation.addedNodes.length > 0) {
      const addedNodes = mutation.addedNodes;

      Array.from(addedNodes).forEach((node) => {
        if (node.nodeName === 'DIV' || node.nodeName === 'INPUT') {
          // Execute your function here...
        }
      });
    }
  });
});

observer.observe(targetElement, { childList: true, subtree: true });
時執行函數分區>或加入 HTML 中,這是一個實際範例:

以上是如何在 JavaScript 中偵測並回應 DOM 變更?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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