mirror of
https://github.com/qier222/YesPlayMusic.git
synced 2025-03-02 09:37:23 +08:00
22 lines
546 B
TypeScript
22 lines
546 B
TypeScript
import { useState, useEffect, RefObject } from 'react'
|
|
|
|
const useIntersectionObserver = (element: RefObject<Element>): { onScreen: boolean } => {
|
|
const [onScreen, setOnScreen] = useState(false)
|
|
|
|
useEffect(() => {
|
|
if (element.current) {
|
|
const observer = new IntersectionObserver(([entry]) => setOnScreen(entry.isIntersecting))
|
|
observer.observe(element.current)
|
|
return () => {
|
|
observer.disconnect()
|
|
}
|
|
}
|
|
}, [element, setOnScreen])
|
|
|
|
return {
|
|
onScreen,
|
|
}
|
|
}
|
|
|
|
export default useIntersectionObserver
|