探索 Framer Motion 高级动画技巧:提升前端设计水平

在现代的网页和应用设计中,动画不仅仅是视觉的点缀,更是用户体验的重要组成部分。它能够使界面更具吸引力,提升交互的流畅性,甚至在不经意间传达品牌的个性和态度。然而,要创造出令人惊叹的动效并不容易——直到有了 Framer Motion。本文将带你深入探索 Framer Motion 的奥秘,掌握其核心概念和实用技巧,助你在界面设计的旅程中走得更远。

Framer Motion:是一个专业的动画和交互效果库,特别设计用于React应用程序的创建,它提供了简单且强大的工具,帮助开发者和设计师轻松地实现复杂的动画效果,从而增强用户界面的视觉吸引力和交互性,通过使用Framer Motion开发者可以轻松地创建各种动画,如过渡动画、交互式元素动画和响应式布局动画,从而提升其应用程序的用户体验,其官方地址为:地址 :

目前Framer Motion需要React 18版本才可以,低版本的react项目是无法使用的,终端执行如下命令安装,如果是项目是升级到React 19的用户可以安装Framer Motion 12 alpha版,它目前可与React 19 RC配合使用,安装命令如下(因为大部分项目还是react18,所以本文就以18版本举例):

# react18版本可安装
npm install framer-motion# react19版本可安装
npm install framer-motion@12.0.0-alpha.0

Framer Motion提供了一个牛逼的组件:<motion />,该组件可直接将其视为一个普通的HTML或SVG元素,然后我们可以直接为组件设置动画属性的效果,大大增强了动画功能,它可以接受多种属性来定义和控制动画的行为和外观,以下是一些常用的属性及其作用:

1)animate指定元素的动画状态,可以是一个对象,其中包含要动画化的 CSS 属性及其目标值,也可以是预定义的动画变体(如"whileHover")。

2)initial:定义元素的初始状态,当组件首次渲染时,会从这个状态开始动画到 animate 属性定义的状态。

3)exit:定义元素离开动画的状态,当元素即将从 DOM 中移除时,会执行这个状态的动画。

4)transition:定义动画过渡的时间、缓动函数(如 ease-in-out)、延迟等参数。可以是一个对象,每个属性的变化都可以定义不同的过渡效果。

5)variants:定义不同动画状态的集合,用于组件在不同状态之间切换时使用,可以定义多个状态集合,以便根据应用的逻辑选择不同的变体。

6)whileHover、whileTap等:提供预定义的动画状态,当用户与元素交互时自动触发,例如,whileHover 可以定义鼠标悬停时的动画效果。

7)drag、dragConstraints、dragElastic、dragMomentum:用于支持元素的拖拽行为,drag 表示元素是否可拖拽,dragConstraints 定义拖拽的约束条件,dragElastic 控制拖拽松弛度,dragMomentum 控制惯性效果。

8)layout、layoutId:控制元素布局和布局动画,layout 可以使元素根据其父容器重新布局,layoutId 则用于在不同页面或组件之间保持布局的一致性。

这些属性使得 <motion /> 组件非常灵活,能够满足各种复杂的动画和交互设计需求,怎么使用呢?直接打出下面的例子,通过motion组件设置一个div,然后其设置本身的css样式后,然后给组件motion.div设置动画效果:

最终呈现的效果如下所示:

 

当然<motion />也提供了使用强大的手势识别器扩展React的事件系统,它支持悬停、点击、平移和拖动等操作,非常的酷炫,如下给出代码:

import { motion } from "framer-motion";
import './index.less'const Motion = () => {return (<><div className="container"><motion.divclassName="box"initial={{ opacity: 0, scale: 0.5 }} // 初始状态animate={{ opacity: 1, scale: 1 }} // 动画状态transition={{ duration: 2 }} // 动画过渡时长whileHover={{ scale: 1.2 }} // 悬浮状态放大1.2倍whileTap={{ scale: 1.1 }} // 点击状态放大1.1倍drag="x" // 拖拽dragConstraints={{ left: -100, right: 100 }} // 拖拽约束>内容</motion.div></div></>)
};
export default Motion;

上面我们给div设置了hover、tap、drag等效果,这里我们在浏览器看一下,效果非常酷炫呀!

大概的基础演示就这么多,接下来我们开始详细进入到Framer Motion功能性的讲解!

Framer Motion中有多种动画制作方式,这里可根据自身需求的复杂程度进行扩展,那么如何制作动画呢?这里有如下几种方式:

简单过度动画:通过motion组件和animate(动画)与transition(过渡)道具来完成。

<motion.divclassName="box"animate={{ x: 100 }} // 动画状态transition={{ ease: "easeOut", duration: 2 }} // 动画过渡方式:easeOut缓动,持续时间2s
>内容
</motion.div>

当然这两者的搭配也可以实现关键帧动画的效果,其中times是一个与关键帧数组长度相同的数组,其中的数字0和1定义了动画中每个关键帧应该被击中的位置。代码如下:

<motion.divclassName="box"animate={{ scale: [1, 2, 2, 1, 1], rotate: [0, 0, 180, 180, 0],borderRadius: ["0%", "0%", "50%", "50%", "0%"]}} transition={{ duration: 2,ease: "easeInOut",times: [0, 0.2, 0.5, 0.8, 1],repeat: Infinity, // 无限循环repeatDelay: 1 // 重复间隔时间}} 
>内容
</motion.div>

页面呈现的效果如下所示:

进入退出动画:通过motion组件和initial(进入)与exit(退出)道具来完成。

注意:在React中当组件从树中移除时它会被立即移除,Framer Motion提供了AnimatePresence在执行退出动画时将组件保留在 DOM 中的功能,代码如下:

import { useState } from "react";
import { motion, AnimatePresence } from "framer-motion";
import './index.less'const Motion = () => {const [isShow, setIsShow] = useState(true);return (<><div className="container"><AnimatePresence>{ isShow && (<motion.divclassName="box"initial={{ opacity: 0, scale: 0.5, color: '#123456' }} // 初始状态exit={{ color: '#008c8c' }}animate={{ opacity: 1, scale: 1 }} // 动画状态transition={{ ease: "easeOut", duration: 2 }} // 动画过渡方式:easeOut缓动,持续时间2s>内容</motion.div>) }</AnimatePresence><button style={{ width: '100px', height: '30px' }} onClick={() => setIsShow(!isShow)}>显示/隐藏</button></div></>)
};
export default Motion;

最终呈现的效果如下所示:

手势动画:Framer Motion具有在手势开始时将动画设置为一组值的快捷方式,例如hover、tap、drag和focusinView等,它目前支持悬停、点击、平移和拖动手势检测,每个手势都有一系列事件监听器,可以将其附加到您的motion组件上。

<motion.divclassName="box"animate={{ opacity: 1, scale: 1 }} // 动画状态transition={{ ease: "easeOut", duration: 2 }} // 动画过渡方式:easeOut缓动,持续时间2swhileHover={{ scale: 1.2, transition: { duration: 2 } }} // 鼠标悬浮时,scale放大为1.2whileTap={{ scale: 0.8 }} // 鼠标点击时,scale缩小为0.8drag // 拖拽dragConstraints={{ left: 0, top: 0 }} // 拖拽约束dragElastic={0.2} // 拖拽弹性onDragStart={(event, info) => console.log(info.point.x, info.point.y)}onDragEnd={(event, info) => console.log(info.point.x, info.point.y)}
>内容
</motion.div>

呈现的效果如下所示:

动画内容: MotionValue我们可以通过将 a 作为motion组件的子项传递来呈现其当前值。

import { useEffect } from "react";
import { motion, useMotionValue, useTransform, animate } from "framer-motion";
import './index.less'const Motion = () => {const count = useMotionValue(0)const rounded = useTransform(count, latest => Math.round(latest))useEffect(() => {const controls = animate(count, 100, { duration: 10 })return () => controls.stop()}, [])return <motion.div className="box">{rounded}</motion.div>
};
export default Motion;

最终呈现的效果如下所示:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/50008.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

经验——OLED的使用

型号&#xff1a;HS96L01W 4S03 分辨率&#xff1a;120*64 通讯方式&#xff1a;4线SPI 模式00 MCU&#xff1a;MSPM0G3507&#xff08;只影响SPI的配置&#xff09; 原本照着型号搜到了嘉立创的使用文档&#xff0c;但是实际上并不能正常使用&#xff0c;后来寻到了一篇博客…

MFC与QT中禁用Esc、Alt+F4、关闭图标

在业务中&#xff0c;我们需要按指定的方式才能关闭当前对话框。如下图需输入密码点击确认后&#xff0c;界面才能关闭。 方法1&#xff1a;通过禁用界面的按钮以及键盘上对应关闭对话框的按键。 1.灰度化关闭按钮 在对话框初始化部分添加将关闭按钮禁用 //MFC CMenu *pSysMe…

主要的国产信创数据库有哪些

数据库生态分类 当前数据库生态可以大致分类三类: 一、传统商业数据库&#xff0c;以 Oracle 为代表&#xff0c;其在 40 余年时间里所创造的数据库帝国已拥有了极其完善的生态; 二、开源数据库&#xff0c;以 MYSQL、PostgreSQL为代表&#xff0c;遍布全球的社区组织形成了强…

大文件分片上传(前端TS实现)

大文件分片上传 内容 一般情况下&#xff0c;前端上传文件就是new FormData,然后把文件 append 进去&#xff0c;然后post发送给后端就完事了&#xff0c;但是文件越大&#xff0c;上传的文件也就越长&#xff0c;如果在上传过程中&#xff0c;突然网络故障&#xff0c;又或者…

AHK是让任何软件都支持 Shift + 鼠标滚轮 实现界面水平滚动

目录 基本介绍 详细特点 图解安装 下载失败&#xff1f;缓慢&#xff1f; 创建并运行脚本代码&#x1f603; 新建空 xxx.ahk文件 vscode/记事本等编辑工具打开 复制并粘贴简易脚本 运行 其他问题 问题一&#xff1a;弹出无法执行此脚本 关闭脚本 基本介绍 AutoHot…

【MetaGPT系列】【MetaGPT完全实践宝典——如何定义单一行为多行为Agent】

目录 前言一、智能体1-1、Agent概述1-2、Agent与ChatGPT的区别 二、多智能体框架MetaGPT2-1、安装&配置2-2、使用已有的Agent&#xff08;ProductManager&#xff09;2-3、拥有单一行为的Agent&#xff08;SimpleCoder&#xff09;2-3-1、定义写代码行为2-3-2、角色定义2-3…

B站音视频分开 大小问题

音频是33331 kb&#xff0c;视频是374661 kb 合并之后却是2561363 kb 这可能是B站音频和视频分开的原因吧

Zabbix监控案例

文章目录 一、监控linux TCP连接状态TCP端口的十一种连接状态自定义监控项监控示例二、监控模板监控tcp连接监控nginx 一、监控linux TCP连接状态 TCP&#xff0c;全称Transfer Control Protocol&#xff0c;中文名为传输控制协议&#xff0c;它工作在OSI的传输层&#xff0c;…

3.Fabric系统架构、网络拓扑图、交易流程

Hyperledger Fabric系统架构 Fabric网络拓扑图 Fabric交易流程 多通道

【数字范围按位与】python刷题记录

run到位运算。 顿悟&#xff1a; 只看第一个二进制位&#xff0c;只存在0,1两种情况&#xff0c;所以如果left<right&#xff0c;区间中必然存在left1,那么最低位&一下一定等于0了&#xff0c;然后不停的右移&#xff0c;一直移到两个相等为止&#xff0c;就这么简单 …

Qt自定义下拉列表-可为选项设置标题、可禁用选项

在Qt中,ComboBox&#xff08;组合框&#xff09;是一种常用的用户界面控件,它提供了一个下拉列表,允许用户从预定义的选项中选择一个。在项目开发中&#xff0c;如果简单的QComboBox无法满足需求&#xff0c;可以通过自定义QComboBox来实现更复杂的功能。本文介绍一个自定义的下…

二级医院LIS系统源码,医学检验系统,支持DB2,Oracle,MS SQLServer等主流数据库

系统概述&#xff1a; LIS系统即实验室信息管理系统。LIS系统能实现临床检验信息化&#xff0c;检验科信息管理自动化。其主要功能是将检验科的实验仪器传出的检验数据经数据分析后&#xff0c;自动生成打印报告&#xff0c;通过网络存储在数据库中&#xff0c;使医生能够通过医…

7.消息应答

消费者完成一个任务可能需要一段时间&#xff0c;如果其中一个消费者处理一个长时间的任务并且只完成了部分突然就挂掉了&#xff0c;会发生什么情况&#xff1f; RabbitMQ一旦向消费者传递了一条消息&#xff0c;便立即将该消息标记为删除。这种情况下&#xff0c;突然有个消…

代码随想录算法训练营day6 | 242.有效的字母异位词、349. 两个数组的交集、202. 快乐数、1.两数之和

文章目录 哈希表键值 哈希函数哈希冲突拉链法线性探测法 常见的三种哈希结构集合映射C实现std::unordered_setstd::map 小结242.有效的字母异位词思路复习 349. 两个数组的交集使用数组实现哈希表的情况思路使用set实现哈希表的情况 202. 快乐数思路 1.两数之和思路 总结 今天是…

OpenCV 遍历Mat,像素操作,使用TrackBar 调整图像的亮度和对比度 C++实现

文章目录 1.使用C遍历Mat,完成颜色反转1.1 常规遍历方式1.2 迭代器遍历方式1.3指针访问方式遍历&#xff08;最快&#xff09;1.4不同遍历方式的时间对比 2.图像像素操作&#xff0c;提高图像的亮度3.TrackBar 进度条操作3.1使用TrackBar 调整图像的亮度3.2使用TrackBar 调整图…

学术研讨 | 区块链网络体系结构研讨会顺利召开

添加图片注释&#xff0c;不超过 140 字&#xff08;可选&#xff09; 近日&#xff0c;国家区块链技术创新中心组织了“区块链网络体系结构研讨会”&#xff0c;会议面向跨域交互多、计算规模大、数据管理复杂、性能与扩展性要求高等特征的区块链网络的体系结构展开交流研讨&…

docker相关内容学习

一、docker的四部分 二、镜像相关命令 三、容器相关命令

视频生成【文章汇总】SVD, Sora, Latte, VideoCrafter12, DiT...

视频生成【文章汇总】SVD, Sora, Latte, VideoCrafter12, DiT... 数据集指标 【arXiv 2024】MiraData: A Large-Scale Video Dataset with Long Durations and Structured Captions【CVPR 2024】VBench : Comprehensive Benchmark Suite for Video Generative Models【arxiv 20…

学习记录——day15 数据结构 链表

链表的引入 顺序表的优缺点 1、优点:能够直接通过下标进行定位元素&#xff0c;访问效率高&#xff0c;对元素进行查找和修改比较快 2、不足:插入和删除元素需要移动大量的元素&#xff0c;效率较低 3、缺点:存储数据元素有上限&#xff0c;当达到MAX后&#xff0c;就不能再…

[python]数字与字符串

目录 Python 数字类型转换 Python 数字运算 Python字符串操作 修改 查询 Python 数字数据类型用于存储数值。 数据类型是不允许改变的&#xff0c;这就意味着如果改变数字数据类型的值&#xff0c;将重新分配内存空间。 Python 支持三种不同的数值类型&#xff1a; 整型…