React实现持续旋转的loading动画

实现一个图标的持续旋转效果,css就可以实现。

首先用keyframes定义一个旋转效果:

TypeScript 复制代码
import { keyframes } from '@mui/material';


const rotate = keyframes`
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
`;

这个效果就是旋转360度,接着我们把这个效果应用到具体的图标上,我们使用MUI的一个图标:

TypeScript 复制代码
import RefreshIcon from '@mui/icons-material/Refresh';

然后设置一个class样式:

TypeScript 复制代码
<RefreshIcon className="rotateIcon" fontSize="large" />

rotateIcon就是自定义的样式:

css 复制代码
'.rotateIcon': {
      animation: `${rotate} 0.8s linear infinite`,
 },

animation属性就是设置动画效果,具体参数里, 0.8s是旋转360度的时间,linear是指旋转过程是均匀的速度,infinite是永久,也就是持续不停的旋转。

相关推荐
前端程序猿i10 分钟前
用本地代理 + ZIP 打包 + Excel 命名,优雅批量下载跨域 PDF
前端·javascript·vue.js·html
Danny_FD18 分钟前
Vue2 中使用vue-markdown实现编辑器
前端·javascript·vue.js
用户游民19 分钟前
Flutter 项目热更新加载 libapp.so 文件
前端
coding随想19 分钟前
Vue和React对DOM事件流的处理方法解析
前端
用户479492835691520 分钟前
字节面试官:forEach 为什么不能被中断?
前端·javascript
ccnocare21 分钟前
window.electronAPI.send、on 和 once
前端·electron
tager26 分钟前
🍪 让你从此告别“Cookie去哪儿了?”
前端·javascript·后端
阿吉被迫了解低代码31 分钟前
前端:“学算法?狗都不... !”
前端
前端赵哈哈37 分钟前
Vue 3 + TypeScript 项目模板
前端·vue.js·vite
南囝coding40 分钟前
命令行神器 The Fuck,敲错命令的后悔药
前端·后端