当前位置: 首页 > article >正文

react和vue图片懒加载及实现原理

一、实现原理

  1. 核心思想

    • 只有当图片出现在视口中时,才加载图片。
    • 利用占位图或占位背景优化用户体验。
  2. 实现技术

    • 监听滚动事件:监听页面滚动,通过计算图片与视口的位置关系,判断是否需要加载图片。
    • Intersection Observer(推荐):现代浏览器提供的 API,用于检测目标元素是否进入视口,比滚动事件性能更好。
  3. 步骤

    • 设置图片的占位符(如灰色背景、默认图片)。
    • 检测图片元素是否进入视口。
    • 当图片进入视口时,将 src 属性替换为实际图片地址。

二、React 实现图片懒加载

1. 使用 Intersection Observer 实现

.

import React, { useRef, useState, useEffect } from 'react';

const LazyImage = ({ src, alt, placeholder, className }) => {
  const [isLoaded, setIsLoaded] = useState(false);
  const imgRef = useRef();

  useEffect(() => {
    const observer = new IntersectionObserver(
      ([entry]) => {
        if (entry.isIntersecting) {
          setIsLoaded(true);
          observer.disconnect(); // 图片加载后停止观察
        }
      },
      { threshold: 0.1 } // 10% 进入视口时触发
    );

    if (imgRef.current) {
      observer.observe(imgRef.current);
    }

    return () => {
      if (observer && imgRef.current) {
        observer.unobserve(imgRef.current);
      }
    };
  }, []);

  return (
    <img
      ref={imgRef}
      src={isLoaded ? src : placeholder}
      alt={alt}
      className={className}
    />
  );
};

export default LazyImage;
2. 第三方库
  • react-lazyload:轻量级懒加载库,支持图片、组件等。
npm install react-lazyload
import React from 'react';
import LazyLoad from 'react-lazyload';

const LazyImage = ({ src, alt, height }) => (
  <LazyLoad height={height} offset={100}>
    <img src={src} alt={alt} />
  </LazyLoad>
);

export default LazyImage;

三、Vue 实现图片懒加载

1. 使用 Intersection Observer
<template>
  <img
    :src="isLoaded ? src : placeholder"
    :alt="alt"
    ref="imageRef"
    class="lazy-image"
  />
</template>

<script>
export default {
  props: {
    src: String,
    placeholder: String,
    alt: String,
  },
  data() {
    return {
      isLoaded: false,
    };
  },
  mounted() {
    const observer = new IntersectionObserver(
      ([entry]) => {
        if (entry.isIntersecting) {
          this.isLoaded = true;
          observer.disconnect();
        }
      },
      { threshold: 0.1 }
    );

    observer.observe(this.$refs.imageRef);
  },
};
</script>
2. 使用指令(全局注册)

懒加载在 Vue 中可通过自定义指令实现:

// directive-lazyload.js
export const lazyload = {
  mounted(el, binding) {
    const loadImage = () => {
      const imageElement = el;
      if (imageElement) {
        imageElement.src = binding.value;
      }
    };

    const observer = new IntersectionObserver(([entry]) => {
      if (entry.isIntersecting) {
        loadImage();
        observer.disconnect();
      }
    });

    observer.observe(el);
  },
};

注册全局指令:

import { lazyload } from './directive-lazyload';
const app = createApp(App);
app.directive('lazyload', lazyload);

使用

<template>
  <img v-lazyload="imageSrc" alt="Lazy loaded image" />
</template>

<script>
export default {
  data() {
    return {
      imageSrc: 'https://example.com/image.jpg',
    };
  },
};
</script>
3. 第三方库
  • vue-lazyload
npm install vue-lazyload
import VueLazyload from 'vue-lazyload';
app.use(VueLazyload, {
  loading: 'path/to/loading-image.png', // 占位图
  error: 'path/to/error-image.png',   // 错误图
});

<template>
  <img v-lazy="imageSrc" alt="Lazy loaded image" />
</template>

四、性能优化与注意事项

  1. 减少主线程开销:优先使用 Intersection Observer,避免滚动事件监听。
  2. 设置占位图:使用占位图片或颜色,避免加载空白区域影响体验。
  3. 图片格式优化
    • 使用 WebP 等高压缩比格式。
    • 根据设备和网络情况选择适配图片(如 srcsetpicture 标签)。
  4. 懒加载阈值:通过设置 offsetthreshold 提前加载,提高滚动时的视觉连续性。
  5. 服务器优化:开启图片的 lazy 属性,结合懒加载策略。

通过上述方法,React 和 Vue 都可以灵活实现高性能的图片懒加载功能。


http://www.kler.cn/a/410482.html

相关文章:

  • ubuntu24挂载硬盘记录
  • 树莓派2装FreeBSD14.1 Raspberry Pi2 install FreeBSD14.1 00000121:error:0A000086:SSL
  • C++ —— 以真我之名 如飞花般绚丽 - 智能指针
  • Ray 和 PyTorch
  • 小U的奖学金申请问题
  • 解锁PPTist的全新体验:Windows系统环境下本地部署与远程访问
  • springboot项目使用maven打包,第三方jar问题
  • Java基础--输入输出
  • STM32 Keil5 attribute 关键字的用法
  • Java爬虫:数据采集的强大工具
  • Perl 简介
  • react函数式组件中的路由传参方式
  • 智慧环保大数据解决方案
  • 如何防止序列化破坏单例模式
  • 探索C/C++的奥秘之stack和queue
  • Python 数据分析核心库大全!
  • 《Python游戏编程入门》注-第8章5
  • go语言range的高级用法-使用range来接收通道里面的数据
  • spark 3.4.4 利用Spark ML中的交叉验证、管道流实现鸢尾花分类预测案例选取最优模型
  • 【zookeeper03】消息队列与微服务之zookeeper集群部署
  • 网络新技术新应用在网络安全领域的发展特点
  • 【GL004】Linux
  • vue3 reactive响应式实现源码
  • CTO 实际上是做什么的?
  • IP Transit國外頻寬使用最高優先權,國內直接與骨幹互連
  • archlinux 触摸板手势配置