はじめに
この実験では、MutationObserver を使用して DOM ツリーに加えられた変更を監視するために、React で useMutationObserver フックをどのように使用するかを学びます。このフックを使用すると、変更が検出されたときに実行するコールバック関数を指定でき、オブザーバーの動作をカスタマイズするためのオプションも提供できます。この実験を通じて、React アプリケーションで useMutationObserver フックをどのように実装するかを理解できるようになります。
React の useMutationObserver フック
index.htmlとscript.jsはすでに仮想マシン (VM) に用意されています。一般的には、script.jsとstyle.cssにコードを追加するだけです。
DOM ツリーに加えられた変更を監視するには、useMutationObserver フックを使用できます。その仕組みは次の通りです。
- このフックは 3 つのパラメーターを受け取ります。
ref、callback、およびoptionsです。 - フックの内部では、
callbackとoptionsの値に依存するuseEffect()フックが使用されます。 - 与えられた
refが初期化されている場合、新しいMutationObserverが作成され、callbackが渡されます。 MutationObserver.observe()が与えられたoptionsで呼び出され、与えられたrefの変更を監視します。- コンポーネントがアンマウントされるときに、
MutationObserver.disconnect()を使用してrefからオブザーバーを削除します。
コードは次のとおりです。
const useMutationObserver = (
ref,
callback,
options = {
attributes: true,
characterData: true,
childList: true,
subtree: true
}
) => {
React.useEffect(() => {
if (!ref.current) return;
const observer = new MutationObserver(callback);
observer.observe(ref.current, options);
return () => observer.disconnect();
}, [callback, options, ref]);
};
App コンポーネントでは、useMutationObserver フックを使用して mutationRef 要素に加えられた変更を監視しています。incrementMutationCount 関数が callback として渡されています。
const App = () => {
const mutationRef = React.useRef();
const [mutationCount, setMutationCount] = React.useState(0);
const incrementMutationCount = React.useCallback(() => {
setMutationCount((count) => count + 1);
}, []);
useMutationObserver(mutationRef, incrementMutationCount);
const [content, setContent] = React.useState("Hello world");
return (
<>
<label htmlFor="content-input">Edit this to update the text:</label>
<textarea
id="content-input"
style={{ width: "100%" }}
value={content}
onChange={(e) => setContent(e.target.value)}
/>
<div style={{ width: "100%" }} ref={mutationRef}>
<div
style={{
resize: "both",
overflow: "auto",
maxWidth: "100%",
border: "1px solid black"
}}
>
<h2>Resize or change the content:</h2>
<p>{content}</p>
</div>
</div>
<div>
<h3>Mutation count {mutationCount}</h3>
</div>
</>
);
};
ReactDOM.createRoot(document.getElementById("root")).render(<App />);
右下隅にある「Go Live」をクリックして、ポート 8080 で Web サービスを実行してください。その後、Web 8080 タブを更新すると、Web ページをプレビューできます。
まとめ
おめでとうございます!React の useMutationObserver フックの実験を完了しました。LabEx でさらに多くの実験を行い、スキルを向上させることができます。