json 动画展示效果-vue

时间:2025-04-08 15:14:32

# json 动画展示效果

## 相关链接

Lottie 官方文档:

vue-lottie 相关 Github 地址:/chenqingspring/vue-lottie

在 vue 里使用 Lottie 动画(实现 json 格式的动画): /qq_44094296/article/details/115717841

## 依赖

需要安装插件

```javascript

npm install --save vue-lottie

```

## 使用

```vue

import lottie from 'vue-lottie' export default{ ... components:{ lottie } ... }

```

## 引入使用的 json 文件

```vue

import * as animationData from '../../assets/data_loop.json';

```

## 使用

```vue

<template>

<lottie

:options="defaultOptions"

:height="400"

:width="400"

@animCreated="handleAnimation"

/>

</template>

<script>

import * as animationData from "../../assets/data_loop.json";

export default {

data() {

return {

defaultOptions: { animationData: animationData },

};

},

methods: {

handleAnimation: function (anim) {

= anim;

},

},

};

</script>

```

## lottie 的参数 options 说明

```

animationData: animationData, //需要引入的json动画对象

renderer: 'svg', //渲染方式,svg、canvas、html(轻量版仅svg渲染)

loop: true, //是否循环播放,true表示循环,false表示不循环

autoplay: true, //是否自动播放,true表示自动播放

```

## 常用方法

```

(); // 播放该动画,从目前停止的帧开始播放

(); // 停止播放该动画,回到第0帧

(); // 暂停该动画,在当前帧停止并保持

(value, isFrame); // 跳到某个时刻/帧并停止。isFrame(默认false)指示value表示帧还是时间(毫秒)

(value, isFrame); // 跳到某个时刻/帧并从该帧往后进行播放

(30, true); // 跳转到第30帧并停止

(300); // 跳转到第300毫秒并从300毫秒开始向后播放

(arr, forceFlag); // 播放片段,arr可以包含两个数字或者两个数字组成的数组,forceFlag表示是否立即强制播放该片段,如果是false则需等前一个动画结束后开始播放,如果是true,则立即开始播放

([10,20], false); // 播放完之前的片段,播放10-20帧

([[0,5],[10,18]], true); // 直接播放0-5帧和10-18帧

(speed); // 设置播放速度,speed为1表示正常速度

(direction); // 设置播放方向,1表示正向播放,-1表示反向播放

(); // 删除该动画,移除相应的元素标签等。在unmount的时候,需要调用该方法

```