Введение
В этом практическом занятии (lab) мы узнаем, как использовать хук useMutationObserver в React для отслеживания изменений в DOM-дереве с помощью MutationObserver. Этот хук позволяет нам указать функцию обратного вызова (callback function), которая будет выполняться при обнаружении изменений, а также предоставить параметры (options), чтобы настроить поведение наблюдателя. В рамках этого практического занятия мы сможем понять, как реализовать хук useMutationObserver в наших React-приложениях.
Хук React useMutationObserver
Файлы
index.htmlиscript.jsуже предоставлены в виртуальной машине (VM). Как правило, вам нужно добавить код только в файлыscript.jsиstyle.css.
Для отслеживания изменений в DOM-дереве можно использовать хук useMutationObserver. Вот как он работает:
- Хук принимает три параметра:
ref,callbackиoptions. - Внутри хука используется хук
useEffect(), который зависит от значенийcallbackиoptions. - Если заданный
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 8080, чтобы предварительно просмотреть веб-страницу.
Итог
Поздравляем! Вы завершили практическое занятие (lab) по хоку React useMutationObserver. Вы можете попрактиковаться в других практических занятиях в LabEx, чтобы улучшить свои навыки.