react实现图片懒加载

1. 准备测试数据

const Urls: string[]=[
"https://img95.699pic.com/photo/50070/5999.jpg_wh860.jpg",
"https://pic3.zhimg.com/v2-d1f733345b0d11ea4d1bde0e2511dbc8_720w.jpg?source=172ae18b",
"https://ts1.cn.mm.bing.net/th/id/R-C.b2deabf4f73362fdeded6ebb1759e6d5?rik=QTdjsA3RyD4v4g&riu=http%3a%2f%2fn.sinaimg.cn%2fsinacn20107%2f549%2fw600h749%2f20190427%2f07db-hvvuiyp2168388.jpg&ehk=ea6ytlOusTMhUxs4TgDNYQqymM8voeFn9db9ZiNcMOk%3d&risl=&pid=ImgRaw&r=0"];

2. 封装组件

const ImageLazy = () => {
    const observer: React.MutableRefObject<any> = useRef();
    useEffect(() => {
        observer.current = new IntersectionObserver(entries => {
            entries.forEach((item: any) => {
                if (item.intersectionRatio > 0) {
                    myLazy(item.target)
                }
            })
        }, {
            root: document.querySelector('#lazyImgDeom')
        })
        handleImgShow();
        return () => {
            observer.current.disconnect();
        };
    }, [])

    const myLazy = (dom:HTMLImageElement) => {
        if (!dom.src || dom.src !== dom.dataset.src) {
            dom.src = dom.dataset.src as string;
        }
        dom.onload = () => {
            dom.style.backgroundColor = '';
            dom.style.aspectRatio = '';
        }
    }

    const handleImgShow = useCallback(() => {
        const list = [...(document.getElementById("imgList") as HTMLElement).getElementsByTagName("img")];
        list.forEach(img => observer.current.observe(img))
    }, [])

    return <div className={styles.lazyImgDeom} id="lazyImgDeom">
        <div className={styles.imgList} id="imgList">
            {
                Urls.map(url => <img className={styles.imgItem} data-src={url} key={url} />)
            }
        </div>
    </div>
}

export default ImageLazy

  • 9
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
React实现列表图片懒加载,我们可以结合使用 `react-lazyload` 库和 `Intersection Observer API`。以下是基于这两个工具的实现步骤: 1. 首先,安装 `react-lazyload` 库。 ```bash npm install react-lazyload ``` 2. 在列表组件中引入 `react-lazyload` 组件,并使用 `Intersection Observer API` 监听图片是否进入可视区域。 ```jsx import React from 'react'; import LazyLoad from 'react-lazyload'; const ListItem = ({ imageUrl, altText }) => { return ( <LazyLoad> <img src={imageUrl} alt={altText} /> </LazyLoad> ); }; const ListComponent = ({ items }) => { return ( <ul> {items.map((item) => ( <li key={item.id}> <ListItem imageUrl={item.imageUrl} altText={item.altText} /> </li> ))} </ul> ); }; export default ListComponent; ``` 在上述代码中,我们使用 `react-lazyload` 组件包裹了 `<img>` 元素,并将图片的地址和替代文本作为属性传递给子组件 `ListItem`。当图片进入可视区域时,`react-lazyload` 会自动加载图片。 3. 在父组件中使用 `ListComponent`,并传递图片数据给列表组件。 ```jsx import React from 'react'; import ListComponent from './ListComponent'; const App = () => { const items = [ { id: 1, imageUrl: 'image1.jpg', altText: 'Image 1' }, { id: 2, imageUrl: 'image2.jpg', altText: 'Image 2' }, { id: 3, imageUrl: 'image3.jpg', altText: 'Image 3' }, // 更多图片数据 ]; return ( <div> <h1>List of Images</h1> <ListComponent items={items} /> </div> ); }; export default App; ``` 在父组件中,我们创建了一个包含图片数据的数组,并将其传递给列表组件 `ListComponent`。列表组件会根据传递的数据生成相应的图片项。 通过以上步骤,我们可以在 React实现列表图片懒加载。 `react-lazyload` 库会自动处理图片的加载,只有当图片进入可视区域时才进行加载,从而提升页面性能和用户体验。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值