[React] Import on Visibility

Source: https://javascriptpatterns.vercel.app/patterns/performance-patterns/import-on-visibility

 

One way to dynamically import components on interaction, is by using the Intersection Observer API. There's a React hook called react-intersection-observer that we can use to easily detect whether a component is visible in the viewport.

import { Suspense, lazy } from "react";
import { useInView } from "react-intersection-observer";
const Listing = lazy(() => import("./components/Listing"));

function ListingCard(props) {
  const { ref, inView } = useInView();

  return (
    <div ref={ref}>
      <Suspense fallback={<div />}>{inView && <Listing />}</Suspense>
    </div>
  );
}

 

posted @   Zhentiw  阅读(28)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
历史上的今天:
2021-08-26 [CSS 3] Solved: DOM element which is visible but not clickable: pointer-events
2021-08-26 [Cloud Architect] 2. Resiliency
2020-08-26 [Machine Learning] Cost Function for Logistic Regression Model
2018-08-26 [Typescript Kaop-ts] Use AOP in Vue Components with TypeScript and Kaop-ts
2015-08-26 [React] React Fundamentals: JSX Deep Dive
2015-08-26 [React] React Fundamentals: Build a JSX Live Compiler
点击右上角即可分享
微信分享提示