有一个视频自动播放的需求,但是需要懒加载,避免阻塞页面渲染
在useEffect里面加入IntersectionObserver
IntersectionObserver 接口(从属于 Intersection Observer API)提供了一种异步观察目标元素与其祖先元素或顶级文档视口(viewport)交叉状态的方法。其祖先元素或视口被称为根(root)。
当一个 IntersectionObserver 对象被创建时,其被配置为监听根中一段给定比例的可见区域。一旦 IntersectionObserver 被创建,则无法更改其配置,所以一个给定的观察者对象只能用来监听可见区域的特定变化值;然而,你可以在同一个观察者对象中配置监听多个目标元素。
const videoRef = useRef<any>(null)
useEffect(() => {
if (!('IntersectionObserver' in window)) {
// If IntersectionObserver is not supported, load the video immediately
if (videoRef.current && appConfig?.videoUrl