使用 Framer Motion 实现滚动动画

Framer Motion 是一个强大的 React 动画库,它提供了简单、强大和可扩展的 API,用于创建各种类型的动画效果。

本文介绍Framer Motion 的基本使用,和如何使用其提供的 API 快速实现滚动动画。

基本使用

Framer Motion 的核心是提供了 HTML 元素和 SVG 元素对应的 motion组件,将对应的元素替换为 motion 组件,并且属性配置简单的初始状态、目标状态和过渡效果即可实现动画效果。

tsx 复制代码
import { motion } from 'framer-motion';

const App = () => {
  return (
    <motion.div
      initial={{ opacity: 0, scale: 0 }}
      animate={{ opacity: 1, scale: 1}}
      transition={{ duration: 0.5 }}
    >
      Hello Framer Motion!
    </motion.div>
  );
};

在这个示例中,我们使用 motion.div 包裹一个 <div> 元素,然后定义了 initialanimatetransition 属性来指定初始状态、目标状态和过渡效果。在初始状态下,元素的透明度(opacity)和缩放比例(scale)都是 0,然后通过 animate 属性指定了目标状态,透明度和缩放比例都是 1。transition 属性定义了过渡效果的持续时间为 0.5 秒。

滚动动画

实现常见的页面滚动到指定元素时展示动画,只需要使用 whileInView 这个属性定义元素出现时的样式,比如透明度,大小,偏移位置等。

示例代码如下,定义刚开始时透明度为 0(即不可见),当滚动到元素时设置为透明度 1,元素可见并且会一淡入的动画效果展示。

tsx 复制代码
<motion.div
  initial={{ opacity: 0 }}
  whileInView={{ opacity: 1 }}
/>

实现效果图:

通过设置其他更多样式和属性,我们可以更自由的配置想要的动画效果。如初始位置为 30px,元素可见时从上往下展示,通过 viewporttransition 属性设置动画的展示时机和方式。

tsx 复制代码
<motion.div
  initial={{ opacity: 0, y: 30 }}
  whileInView={{ opacity: 1, y: 0 }}
  viewport={{ once: true }}
  transition={{ duration: 1 }}
>

Framer Motion 是一个强大的动画库,能实现各种简单和复杂的动画效果,更多的使用方式和动画效果可以参考Framer Motion 文档

参考链接

相关推荐
哆啦A梦158812 小时前
Vue3魔法手册 作者 张天禹 11_自定义hooks
前端·vue.js·typescript
广州华水科技12 小时前
单北斗变形监测在大坝安全和地质灾害预警中的应用与优势
前端
阿珊和她的猫12 小时前
深入理解 Vue 3 的 `setup` 函数
前端·vue.js·状态模式
weixin1997010801612 小时前
微店商品详情页前端性能优化实战
前端·性能优化
星火开发设计12 小时前
STL 容器:vector 动态数组的全面解析
java·开发语言·前端·c++·知识
天開神秀12 小时前
解决 n8n 在 Windows 上安装社区节点时 `spawn npm ENOENT/EINVAL` 错误
前端·windows·npm
工业HMI实战笔记12 小时前
图标标准化:一套可复用的工业图标库设计指南
前端·ui·性能优化·自动化·汽车·交互
2501_9269783313 小时前
分形时空理论框架:从破缺悖论到意识宇宙的物理学新范式引言(理论概念版)--AGI理论系统基础1.1
java·服务器·前端·人工智能·经验分享·agi
We་ct13 小时前
LeetCode 146. LRU缓存:题解+代码详解
前端·算法·leetcode·链表·缓存·typescript
SuperEugene13 小时前
数组查找与判断:find / some / every / includes 的正确用法
前端·javascript