群友:这个你能写出来不

简介: 群友:这个你能写出来不

点赞


昨天在群里闲聊的时候,有个朋友突然录了这样一个视频,然后问了一句:

当然可以,有一种高逼格的解决方案不用我们前端写多少代码就能快速实现。


他就是大名鼎鼎的 Lottie。俗称「老铁」


五分钟后,我就给这位同学写了一个 动画 demo。

Lottie 是 Airbnb 开发的一款能够为几乎所有的客户端添加动画效果的开源工具,目前我已经在 iOS、Android、RN、小程序、web 上都使用过 Lottie 来添加我的动画。


只需要花两分钟时间,我们就可以知道如何实现这种比较炫酷的动画效果。


第一步,获取动画源文件


Lottie 原理是播放一个动画文件,我们可以通过该动画内容支持的开始、结束、暂停、是否循环等方式来选择合适的操作方式。因此,动画源文件的来源就变得非常重要。


最理想的方式是选择一个适合你当前项目的 UI 风格,因此设计该动画的职责就需要你们项目团队的 UI 设计师来完成。UI 设计师可以通过 Adobe After Effects 来设计充满想象力的动画效果,然后使用 Lottie 提供的 Bodymovin 插件将设计好的动画导出为一个 JSON 文件。


拿到这个 JSON 文件之后,就开始在页面上开始快速实现该动画了。


如果你们团队没有厉害的 UI 设计师,需要我们前端自己去寻找风格相近的动画,我们也可以在下面这个网站上去寻找,这里有大量的已经做好的 Lottie 动画。

该网站提供了部分免费的 Lottie 动画,还有许多你满意的动画源文件是收费的,我们可以通过开发者工具,找到对应动画的DOM节点,直接获取 JSON 内容。


除此之外,蚂蚁设计团队还给我们提供了一个 Lottie 动画在线设计工具:犸良动画平台。

这里提供了大量的插图、金币红包、人物、按钮、氛围、图标等动画效果,我们可以自由组合设计,最后导出生成我们需要的 JSON 文件。


第二步:找到对应的 npm 包


此处以 React 为例,我们在 npm 上找到一个名为 react-lottie 的包,引入到你的项目中,结合刚才得到的 JSON 动画源文件,就可以快速实现了。


demo 代码如下:

import React, { useState } from 'react';
import Lottie from 'react-lottie'
import * as animateData from './01.json'
import * as data2 from './02.json'
export default function LittieDemo() {
  const [play, setPlay] = useState(false)
  const [paused, setPaused] = useState(false)
  const option = {
    loop: true,
    autoplay: true,
    animationData: animateData,
    renderSettings: {
      preserveAspectRatio: 'xxx'
    }
  }
  const option2 = {
    loop: true,
    autoplay: true,
    animationData: data2,
    renderSettings: {
      preserveAspectRatio: 'xxx'
    }
  }
  return (
    <div>
      <Lottie options={option} height={200} width={200} isPaused={paused} />
      <Lottie options={option2} height={200} width={200} isPaused={paused} />
    </div>
  )
}

OK,我好了。

相关文章
|
3月前
|
API C# 开发者
一款开源免费美观的WinForm UI控件库
一款开源免费美观的WinForm UI控件库
428 9
|
3月前
|
存储 缓存 算法
【计算机网络】数据链路层
【计算机网络】数据链路层
122 0
【计算机网络】数据链路层
|
3月前
|
安全 Linux 云计算
线下参会 免费领票!阿里云分论坛邀您探讨智算时代下的云计算 | 2023龙蜥操作系统大会
1、阿里云和学术界的合作,将理论与实践相结合,在龙蜥孵化更好的操作系统技术。 2、操作系统作为软硬协同的纽带,通过南北向的协同,更好的释放云上算力。 3、阿里云结合龙蜥社区技术为用户提供多样性迁移方案,解决 CentOS 停服的影响、为跨架构迁移提供全链路保障。
|
3月前
|
XML Java 数据格式
Spring之IOC
Spring框架的核心就是IOC和AOP,本篇文章就讲述一下其中的IOC容器。
299 1
Spring之IOC
|
3月前
|
机器学习/深度学习 算法 数据挖掘
【MATLAB】BiGRU神经网络时序预测算法
【MATLAB】BiGRU神经网络时序预测算法
1026 1
|
3月前
|
前端开发 JavaScript API
拥抱华为,困难重重,第一天学习 arkUI,踩坑踩了一天
拥抱华为,困难重重,第一天学习 arkUI,踩坑踩了一天
161 0
|
3月前
|
前端开发 JavaScript 数据管理
CPU都被干冒烟了,拥抱HarmonyOS第二天,自定义组件(上)
CPU都被干冒烟了,拥抱HarmonyOS第二天,自定义组件
|
3月前
|
存储 前端开发
useSyncExternalStore,一个陌生但重要的 hook
useSyncExternalStore,一个陌生但重要的 hook
368 0
|
3月前
|
JavaScript 前端开发 开发者
用 React/Vue 不如用 jQuery
用 React/Vue 不如用 jQuery
113 0
|
3月前
|
JavaScript 前端开发 程序员
TypeScript 类型体操,无非是语法过度嵌套而已
TypeScript 类型体操,无非是语法过度嵌套而已