A simple wrapper around MutationObserver API to watch DOM changes.
이 스크립트는 직접 설치하는 용도가 아닙니다. 다른 스크립트에서 메타 지시문 // @require https://update.greasyfork.org/scripts/488160/1332706/make-mutation-observer.js을(를) 사용하여 포함하는 라이브러리입니다.
// ==UserScript== // @name make-mutation-observer // @description A simple wrapper around MutationObserver API to watch DOM changes. // @version 0.0.1 // @namespace owowed.moe // @author owowed <[email protected]> // @license LGPL-3.0 // ==/UserScript== /** * @typedef {MutationObserverInit & { * target: HTMLElement, * abortSignal?: AbortSignal, * once?: boolean * }} MakeMutationObserverOptions */ /** * @typedef {(info: { records: MutationRecord[], observer: MutationObserver }) => void} MakeMutationObserverCallback */ /** * Create a new `MutationObserver` with options and callback. * @param {MakeMutationObserverOptions} options * @param {MakeMutationObserverCallback} callback * @returns {MutationObserver} */ function makeMutationObserver({ target, abortSignal, once, ...options }, callback) { const observer = new MutationObserver(records => { abortSignal?.throwIfAborted(); if (once) observer.disconnect(); callback({ records, observer }); }); observer.observe(target, options); abortSignal?.addEventListener("abort", () => { observer.disconnect(); }); return observer; }