react-use/src/useWindowScroll.ts
jeemyeong 5987cc82cc feat: useWindowScroll - for cross-browser compatibility
For cross-browser compatibility, use window.pageYOffset instead of window.scrollY.
(https://developer.mozilla.org/en-US/docs/Web/API/Window/scrollY)
2019-07-22 20:44:55 +09:00

42 lines
890 B
TypeScript

import { useEffect, useRef, useState } from 'react';
import { isClient } from './util';
export interface State {
x: number;
y: number;
}
const useWindowScroll = (): State => {
const frame = useRef(0);
const [state, setState] = useState<State>({
x: isClient ? window.pageXOffset : 0,
y: isClient ? window.pageYOffset : 0,
});
useEffect(() => {
const handler = () => {
cancelAnimationFrame(frame.current);
frame.current = requestAnimationFrame(() => {
setState({
x: window.pageXOffset,
y: window.pageYOffset,
});
});
};
window.addEventListener('scroll', handler, {
capture: false,
passive: true,
});
return () => {
cancelAnimationFrame(frame.current);
window.removeEventListener('scroll', handler);
};
}, []);
return state;
};
export default useWindowScroll;