mirror of
https://github.com/ant-design/ant-design.git
synced 2024-12-04 08:59:40 +08:00
33 lines
772 B
TypeScript
33 lines
772 B
TypeScript
|
import { useEffect, useRef } from 'react';
|
||
|
|
||
|
export default function useMutationObserver() {
|
||
|
const instance = useRef<MutationObserver>();
|
||
|
|
||
|
const destroyObserver = () => {
|
||
|
if (instance.current) {
|
||
|
instance.current.takeRecords();
|
||
|
instance.current.disconnect();
|
||
|
instance.current = undefined;
|
||
|
}
|
||
|
};
|
||
|
|
||
|
const createObserver = (target: Node, callback: MutationCallback) => {
|
||
|
if (MutationObserver) {
|
||
|
destroyObserver();
|
||
|
instance.current = new MutationObserver(callback);
|
||
|
instance.current.observe(target, {
|
||
|
childList: true,
|
||
|
subtree: true,
|
||
|
attributeFilter: ['style', 'class'],
|
||
|
});
|
||
|
}
|
||
|
};
|
||
|
|
||
|
useEffect(() => () => destroyObserver(), []);
|
||
|
|
||
|
return {
|
||
|
createObserver,
|
||
|
destroyObserver,
|
||
|
};
|
||
|
}
|