在React中实现好看的动画Framer Motion(案例:滚动进度条)

前言

介绍

Framer Motion 是一个适用于 React 网页开发的动画库,它可以让开发者轻松地在他们的项目中添加复杂和高性能的动画效果。该库提供了一整套针对 React 组件的动画、过渡和手势处理功能,使得通过声明式的 API 来创建动画变得简单直观。

接下来我将带你使用 Framer Motion 实现一个滚动进度条案例,用于实时显示滚动进度。

案例

2023-12-18_20-41-30.gif

基本环境

本案例基于 Vite + React + TypeScript + TailwindCSS 搭建。TailwindCSS 不是必须的,我主要是为了不写 CSS 样式,若想实现和本案例相同的效果,可以安装一下 TailwindCSS

完整代码

import { motion, useScroll } from "framer-motion";

function App() {
  const { scrollYProgress } = useScroll();

  return (
    <>
      <motion.div
        className="fixed inset-x-0 top-0 z-50 h-2 origin-left bg-red-400"
        style={{
          scaleX: scrollYProgress,
        }}
      />
      <div className="mx-auto max-w-2xl py-4">
        {Array.from({ length: 10 }, (_, index) => (
          <div className="mb-4 h-40 rounded-md bg-gray-100">{index}</div>
        ))}
      </div>
    </>
  );
}

export default App;

useScroll 也可以传入一些参数,比如,我想监听某个容器的滚动而不是页面的滚动,我们就可以修改为以下代码。

import { useRef } from "react";
import { motion, useScroll } from "framer-motion";

function App() {
  const ref = useRef<HTMLDivElement>(null);
  const { scrollYProgress } = useScroll({
    container: ref,
  });

  return (
    <>
      <motion.div
        className="fixed inset-x-0 top-0 z-50 h-2 origin-left bg-red-400"
        style={{
          scaleX: scrollYProgress,
        }}
      />
      <div className="mx-auto max-w-2xl py-4">
        <div ref={ref} className="h-80 overflow-y-auto">
          {Array.from({ length: 10 }, (_, index) => (
            <div className="mb-4 h-40 rounded-md bg-gray-100">{index}</div>
          ))}
        </div>
      </div>
    </>
  );
}

export default App;

2023-12-18_23-35-10.gif

还有一些其他常用的参数,比如 targetoffset,感兴趣的小伙伴可以去官网了解一下如何使用。


http://www.niftyadmin.cn/n/5274644.html

相关文章

pgsql的jsonb相关处理及样例

目录 1、某个字段中包含目标list中的全部使用>&#xff1a; 2、某个字段中包含目标list中任意值使用?|&#xff1a; 3、其他操作样例&#xff1a; 1、某个字段中包含目标list中的全部使用>&#xff1a; SELECT * FROM "public"."t_a" WHERE a::j…

Python Opencv实践 - 手部跟踪

使用mediapipe库做手部的实时跟踪&#xff0c;关于mediapipe的介绍,请自行百度。 mediapipe做手部检测的资料&#xff0c;可以参考这里&#xff1a; MediaPipe Hands: On-device Real-time Hand Tracking 论文阅读笔记 - 知乎论文地址&#xff1a; https://arxiv.org/abs/2006…

网络安全—四种攻击方式

四种攻击方式的概述 ARP攻击 概念 ARP协议的基本功能就是通过目标设备的IP地址&#xff0c;在局域网发送广播包&#xff0c;查询目标设备的MAC地址&#xff0c;以保证通信的进行。 ARP攻击 基于ARP协议的这一工作特性&#xff0c;黑客向对方计算机不断发送有欺诈性质的ARP数…

AIOps探索 | 基于大模型构建高效的运维知识及智能问答平台(1)

原作者&#xff1a;擎创科技产品专家 布博士 提升运维效率对于任何组织都至关重要。在追求高效运维的过程中&#xff0c;一个关键步骤就是建立丰富的知识共享平台&#xff0c;它能够为团队成员提供一个共享经验、解决方案和最佳实践。通过知识共享&#xff0c;团队可以更快地解…

Vue+ElementUI前端添加展开收起搜索框按钮

1、搜索框添加判断 v-if"advanced" <el-form-item label"创建日期" v-if"advanced"><el-date-pickerv-model"daterangeLedat"size"small"style"width: 240px"value-format"yyyy-MM-dd"type&q…

iPhone手机开启地震预警功能

iPhone手机开启地震预警功能 地震预警告警开启方式 地震预警 版权&#xff1a;成都高新减灾研究所 告警开启方式

TransXNet实战:使用 TransXNet实现图像分类任务(二)

文章目录 训练部分导入项目使用的库设置随机因子设置全局参数图像预处理与增强读取数据设置Loss设置模型设置优化器和学习率调整策略设置混合精度&#xff0c;DP多卡&#xff0c;EMA定义训练和验证函数训练函数验证函数调用训练和验证方法 运行以及结果查看测试完整的代码 在上…

CogVLM与CogAgent:开源视觉语言模型的新里程碑

引言 随着机器学习的快速发展&#xff0c;视觉语言模型&#xff08;VLM&#xff09;的研究取得了显著的进步。今天&#xff0c;我们很高兴介绍两款强大的开源视觉语言模型&#xff1a;CogVLM和CogAgent。这两款模型在图像理解和多轮对话等领域表现出色&#xff0c;为人工智能的…