mirror of
https://github.com/DefectingCat/DefectingCat.github.io
synced 2025-07-16 01:01:38 +00:00
* add menu item * add pages * add build search script Add custom algolia component * fix image in post width Delete useless file Modify post data to algolia script
56 lines
1.3 KiB
TypeScript
56 lines
1.3 KiB
TypeScript
import { useEffect, useRef, useState } from 'react';
|
|
|
|
/**
|
|
* Use IntersectionObserver API to lazy load taget DOM.
|
|
* @param src src path
|
|
* @param blurPx blur px
|
|
* @returns
|
|
*/
|
|
const useLazyLoad = (src: string, blurPx = '10px') => {
|
|
const targetRef = useRef(null);
|
|
const [blur, setBlur] = useState(`blur(${blurPx})`);
|
|
|
|
const [initSrc, setInitSrc] = useState(
|
|
''
|
|
);
|
|
|
|
const cleanBlur = () => {
|
|
setBlur('unset');
|
|
};
|
|
|
|
useEffect(() => {
|
|
// Lazy load images when they entry the view port.
|
|
const observer = new IntersectionObserver((entries, observer) => {
|
|
entries.forEach((entry) => {
|
|
if (entry.isIntersecting) {
|
|
if (targetRef.current) {
|
|
setInitSrc(src);
|
|
observer.unobserve(targetRef.current);
|
|
(targetRef.current as HTMLElement).addEventListener(
|
|
'load',
|
|
cleanBlur
|
|
);
|
|
}
|
|
}
|
|
});
|
|
});
|
|
|
|
targetRef.current && observer.observe(targetRef.current);
|
|
|
|
const cleanRef = targetRef.current;
|
|
// Clean up the images event listener.
|
|
return () => {
|
|
cleanRef &&
|
|
(cleanRef as HTMLElement).removeEventListener('load', cleanBlur);
|
|
};
|
|
}, [src]);
|
|
|
|
return {
|
|
initSrc,
|
|
blur,
|
|
targetRef,
|
|
};
|
|
};
|
|
|
|
export default useLazyLoad;
|