Vue轮子-Lottie-动画实现

article/2025/10/16 18:47:54

不要问为什么  没有为什么。浮躁的7月首周。Keep Going And Stay Strong。


Lottie是一个IOS,Android和React Native库,可以实时渲染动画,动画被转化成JSON文件,节省了很多资源,允许应用程序像使用静态图像一样轻松使用动画,主要是展示型的动画,交互的不太好实现。网上也有丰富的动画资源,点此进入LottieFiles,里面可以直接下载JSON格式的动画文件,很炫酷。还有可以自己编辑Lottie动画的工具LottieEditor。

这里主要讲Vue项目里使用Lottie,简单封装一个展示动画的通用组件,原生的不太会搞,然后还搜了一下原理,没看懂。

上图。

TestLottie

1.vue-lottie安装

npm install --save vue-lottie

2. 简单封装

<template><div ref="lavContainer"></div>
</template><script lang="ts">
import { Component, Ref, Vue, Prop, Emit } from "vue-property-decorator";
import lottie from "lottie-web";@Component
export default class Lottie extends Vue {@Prop() options!: any;@Ref() readonly lavContainer!: HTMLElement;anim!: Object;mounted() {this.anim = lottie.loadAnimation({container: this.lavContainer,renderer: "svg",loop: true,autoplay: true,animationData: this.options.animationData,rendererSettings: this.options.rendererSettings});this.$emit("animCreated", this.anim);}
}
</script>

3.使用

里面加了 停止stop()  播放play()  暂停pause() 方法,并且可以设置动画速度。
animationData 是动画的Json格式。

<template><div><Lottiev-if="show":options="defaultOptions"style="width:200px;"v-on:animCreated="handleAnimation"/><div @click="switchLottie">点击开始</div><div v-if="show"><p>Speed: x{{ animationSpeed }}</p><inputtype="range"value="1"min="0"max="3"step="0.5"@change="onSpeedChange"v-model="animationSpeed"/><br /><button @click="stop">stop</button><button @click="pause">pause</button><button @click="play">play</button></div></div>
</template><script lang="ts">
import { Component, Ref, Vue, Provide } from "vue-property-decorator";
import Lottie from "./Lottie.vue";
import animationData from "@/assets/gif/loader.json";@Component({components: { Lottie }
})
export default class Test extends Vue {defaultOptions = { animationData: animationData };animationSpeed: number = 1;anim?: any;show = false;switchLottie() {this.show = !this.show;}handleAnimation(a: object) {this.anim = a;}stop() {this.anim.stop();}play() {this.anim.play();}pause() {this.anim.pause();}onSpeedChange() {this.anim.setSpeed(this.animationSpeed);}
}
</script>


相关网站:

官网:https://airbnb.design/lottie/
gayHub: https://github.com/airbnb/lottie-web
Lottie 库和插件:https://lottiefiles.com/
轮子工厂:http://www.wheelsfactory.cn/
可编辑Lottie动画工具: https://github.com/sonaye/lottie-editor


http://chatgpt.dhexx.cn/article/uoL6x6DB.shtml

相关文章

java造轮子_RxJava 自己造轮子一

RXJava 造轮子 什么是rxjava? rxjava 是一个响应式编程&#xff0c;为了更好更优雅的处理异步时间&#xff0c;内部实现原理是观察者模式 自己造轮子实现Rxjava 观察者模式核心有两个&#xff0c;一个观察者一个被观察者 先创建一个被观察者observer(基层抽象类) //观察者的基…

react hook 造轮子

GitHub地址:https://github.com/rayhomie/rayhomieUI 一、sass的使用 1、import方式引入scss文件&#xff0c;后面必须带后缀名scss import "main.scss";2、Partials方式引入base.scss文件,文件必须以&#xff08;下划线&#xff09;开头&#xff0c;可以不用带后…

「轮子工厂」谭庆波,很高兴认识大家!

我是谁&#xff1a; 我叫谭庆波&#xff0c;网名厂长。 首先我是一名学生&#xff0c;哈工大计算系的博士生&#xff0c;也是一个喜欢在互联网上折腾的95后。 2015年开始写博客&#xff0c;累计输出博客500多篇&#xff0c;访问量超百万&#xff1b; 2018年开始做公众号和知乎&…

前端轮子厂

1. Element Element-Ul是饿了么前端团队推出的一款基于Vue.js 2.0 的桌面端UI框架&#xff0c;一套为开发者、设计师和产品经理准备的基于 Vue 2.0 的桌面端组件库&#xff0c;手机端有对应框架是Mint UI 。 中文文档&#xff1a;http://element-cn.eleme.io/#/zh-CN github地址…

前端_Vue_1.初识Vue

文章目录 一、前言二、开始1 简介1.1 什么是Vue&#xff1f;1.2 渐进式框架1.3 单文件组件1.4. API风格1.4.1. 选项式API&#xff08;Options API&#xff09;1.4.2. 组合式API&#xff08;Composition API&#xff09;1.4.3. 该选哪个&#xff1f; 2. 快速上手&#xff08;学前…

Nginx-学习一

什么是Nginx Nginx是一个http服务器。 是一个使用c语言开发的高性能的http服务器及反向代理服务器。 Nginx是一款高性能的http 服务器/反向代理服务器及电子邮件&#xff08;IMAP/POP3&#xff09;代理服务器。由俄罗斯的程序设计师Igor Sysoev所开发&#xff0c;官方测试ngin…

Nginx学习二

文章目录 一、proxy_set_header1.1、<span class"katex--inline">http\_host与</span>host区别1、在使用Nginx做反向代理的时候&#xff0c;proxy_set_header功能可以设置反向代理后的http header中的host&#xff0c;1.1.1、 不设置 proxy_set_header H…

nginx学习一

nginx 安装&#xff1a; 1、 ./configure 如果报错 error: C compiler cc is not found 如果没有安装就安装:yum install –y gcc 如果还报错看看是不是安装: yum install –y zlib zlib-devel 2、 安装 make 3、 make install 4、 安装完后可以查看到目录 5、 启动 nginx …

nginx学习记录

一、docker安装nginx和配置文件 &#xff08;1&#xff09;docker拉取镜像 docker pull nginx &#xff08;2&#xff09;创建容器 # 在/root⽬录下创建nginx⽬录⽤于存储nginx数据信息 mkdir ~/nginx cd ~/nginx mkdir conf cd conf # 在~/nginx/conf/下创建nginx.conf⽂件…

尚硅谷nginx学习笔记

尚硅谷nginx学习笔记 1.nginx相关概念1.1什么是nginx&#xff1f;1.2正向和反向代理1.3负载均衡1.4动静分离 2.nginx在linux中的安装与启动3.nginx的常用命令4.nginx的配置文件5.nginx配置实例5.1反向代理准备工作5.2反向代理实例一5.3反向代理实例二5.4负载均衡实例5.5动静分离…

Nginx学习(一)

系统版本CentOS Linux release 7.6.1810 (Core) Nginx作用 反向代理正向代理负载均衡HTTP服务器(包含动静分离) 环境确认 1.关闭iptables规则 如果启动的iptables防火墙不想关闭的话&#xff0c;可以通过iptables -F 来清除防火墙关闭。然后通过iptables -L查看 2.停用seli…

NGINX学习记录-基础入门篇

学习《NGINX 经典教程》林静&#xff0c;刘旭峰&#xff0c;章澍&#xff0c;廖健雄&#xff0c;宗兆伟 ... 著 目录 一、Nginx优点 二、功能(应用场景) 反向代理。 负载均衡 静态缓存 Web服务器 安全和访问控制 三、nginx安装 四、启动、停止和重载nginx 五、配置文…

Nginx学习总结(1):Nginx简介

(最近&#xff0c;部门组织了好几个技术兴趣小组&#xff0c;对当前的热门技术进行研究。我加入了Nginx学习小组&#xff0c;与几个同事一道围绕Nginx来进行研究和学习。从今天起&#xff0c;我会陆陆续续发一系列有关Nginx的学习总结。本文是系列之一&#xff1a;Nginx简介。)…

学习nginx

Nginx笔记 安装nginxwget -c https://nginx.org/download/nginx-1.20.1.tar.gz1、创建软链路ls /usr/local/nginx/sbin/nginx /usr/bin/ 2、前端部署配置 Conf 在这里插入图片描述 3、启动服务 由于软链路 可以直接 nginx 启动&#xff08;任意目录&#xff09; 停止 nginx -s…

nginx学习日记

nginx介绍 1.什么是nginx? nginx就是c语言开发的一个高性能HTTP和反向代理Web服务器以及电子邮件&#xff08;IMAP/POP3&#xff09;代理服务器 nginx是轻量级的。 2.什么是反向代理&#xff1f; 代理服务可以简单的分为正向代理和反向代理。 正向代理&#xff1a;就是代理…

Nginx学习笔记总结:初次认识 Nginx

2022 年 4月 16 日 百思不得小赵 &#x1f50d;点此进入博客主页 —— 新时代的农民工 &#x1f64a; —— 换一种思维逻辑去看待这个世界 &#x1f440; 今天是加入CSDN的第1141天。觉得有帮助麻烦&#x1f44f;点赞、&#x1f340;评论、❤️收藏啦。 概述 Nginx是一个高性能…

Nginx服务器学习

学习思维导图 Nginx服务架构说明 Nginx采用master-worker的架构&#xff0c;和tomacat的按路径匹配一个节点线程进行处理方式不同&#xff0c;Nginx是直接让worker来先抢夺资源也就是请求&#xff0c;然后在去处理&#xff0c;每个worker保持为一个独立的进程。 Nginx服务的实际…

nginx学习,看这一篇就够了

nginx学习&#xff0c;看这一篇就够了&#xff1a;下载、安装。使用&#xff1a;正向代理、反向代理、负载均衡。常用命令和配置文件,很全_冯安晨-CSDN博客_nginx 代理 文件下载文章目录前言一、nginx简介1. 什么是 nginx 和可以做什么事情2.Nginx 作为 web 服务器3. 正向代理4…

Nginx学习+安装

目录 一、Nginx介绍 二、Nginx下载和安装 1.安装过程 三、了解目录结构 小知识点&#xff1a;树形结构目录展示 四、常用命令 五、配置文件结构 六、具体应用 1.部署静态资源 2.反向代理 了解正向代理 反向代理 3.负载均衡 重中之重&#xff1a;更详细的内容可以访…

Nginx学习与安装

Nginx学习与安装 一、Nginx介绍二、Nginx 安装2.1 安装 pcre-8.44.tar.gz2.2 安装openssl与zlib2.3 安装nginx2.4 Nginx 命令 Nginx 配置文件 一、Nginx介绍 是一个高性能的HTTP和反向代理服务器&#xff0c;同时也是一个IMAP/POP3/SMTP 代理服务器。Nginx以事件驱动的方式编写…