首页
/ React Visibility Sensor 使用教程

React Visibility Sensor 使用教程

2026-01-18 10:06:15作者:卓炯娓

项目介绍

React Visibility Sensor 是一个用于检测 React 组件是否在视口(viewport)内可见的库。这个库非常适合用于实现懒加载(lazy loading)、动画效果触发等场景。通过监听组件的可见性变化,开发者可以更灵活地控制页面的行为和性能。

项目快速启动

安装

首先,你需要通过 npm 或 yarn 安装 react-visibility-sensor

npm install react-visibility-sensor
# 或者
yarn add react-visibility-sensor

基本使用

以下是一个简单的示例,展示如何在组件进入视口时触发一个计数器动画:

import React from 'react';
import VisibilitySensor from 'react-visibility-sensor';
import CountUp from 'react-countup';

const CounterSection = () => {
  const onChange = (isVisible) => {
    console.log('Element is now', isVisible ? 'visible' : 'hidden');
  };

  return (
    <div>
      <VisibilitySensor onChange={onChange}>
        <div>
          <CountUp start={0} end={9350} duration={5} />
        </div>
      </VisibilitySensor>
    </div>
  );
};

export default CounterSection;

应用案例和最佳实践

懒加载图片

一个常见的应用场景是懒加载图片,以提高页面加载速度和性能:

import React, { useState } from 'react';
import VisibilitySensor from 'react-visibility-sensor';

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

  const onChange = (isVisible) => {
    if (isVisible && !isLoaded) {
      setIsLoaded(true);
    }
  };

  return (
    <VisibilitySensor onChange={onChange} partialVisibility={true}>
      <div>
        {isLoaded ? <img src={src} alt={alt} /> : <div>Loading...</div>}
      </div>
    </VisibilitySensor>
  );
};

export default LazyImage;

动画触发

另一个常见的应用是当组件进入视口时触发动画效果:

import React, { useState } from 'react';
import VisibilitySensor from 'react-visibility-sensor';
import { motion } from 'framer-motion';

const AnimatedSection = () => {
  const [isVisible, setIsVisible] = useState(false);

  const onChange = (visible) => {
    if (visible) {
      setIsVisible(true);
    }
  };

  return (
    <VisibilitySensor onChange={onChange}>
      <motion.div
        initial={{ opacity: 0, y: 50 }}
        animate={{ opacity: isVisible ? 1 : 0, y: isVisible ? 0 : 50 }}
        transition={{ duration: 0.5 }}
      >
        <h1>Animated Content</h1>
      </motion.div>
    </VisibilitySensor>
  );
};

export default AnimatedSection;

典型生态项目

React CountUp

react-countup 是一个与 react-visibility-sensor 配合使用的库,用于实现数字的动画计数效果。在上面的示例中,我们已经看到了如何结合这两个库来实现一个计数器动画。

Framer Motion

framer-motion 是一个强大的动画库,可以与 react-visibility-sensor 结合使用,实现复杂的动画效果。在上面的动画触发示例中,我们展示了如何使用这两个库来实现一个简单的入场动画。

通过这些示例和最佳实践,你可以更好地理解和应用 react-visibility-sensor,从而提升你的 React 项目的用户体验和性能。

登录后查看全文
热门项目推荐
相关项目推荐