json 动画展示效果-vue

# json 动画展示效果

## 相关链接

Lottie 官方文档:https://lottiefiles.com

vue-lottie 相关 Github 地址:https://github.com/chenqingspring/vue-lottie

在 vue 里使用 Lottie 动画(实现 json 格式的动画): https://blog.csdn.net/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) {

this.anim = anim;

},

},

};

</script>

```

## lottie 的参数 options 说明

```

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

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

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

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

```

## 常用方法

```

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

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

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

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

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

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

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

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

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

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

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

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

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

```

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值