vue使用优化后的动画级别的定时器 requestAnimationFrame 比setInterval, setTimeout效果要高很多

vue使用优化后的动画级别的定时器 requestAnimationFrame 比setInterval, setTimeout效果要高很多

概述

默认情况下,requestAnimationFrame执行频率是1000/60,大概是16ms多执一次。
本文只是写了一个最简单的例子,您可依据业务要求进行套用。

效果图

requestAnimationFrame动画图

完整demo

<template>
<div>
    <div class="box">
        <div class="elem" :style="{left:left+'px'}"></div>
    </div>
    <div class="btns">
        <button @click="stop" :disabled='!isLoop'>停止动画</button>
        <button @click="start" :disabled='isLoop'>重新开始动画</button>
        <button @click="add" :disabled='!isLoop'>加速</button>
        <button @click="sub" :disabled='!isLoop'>减速</button>
    </div>
</div>
</template>

<script>
export default {

    data() {
        return {
            flag: true,
            left: 0,
            max:200,
            step:5,
            rid:'',
            interval:0,
            interval0:1000/60,//动画时间,1s动一下
            nowTime:'',
            lastTime:'',
            isLoop:true,//正在运行
        }
    },

    mounted() {
        this.initInterval()
        this.animLoop()
    },
    methods: {
        initInterval(){
            this.isLoop=false
            this.interval=this.interval0
        },
        animLoop(){
            this.isLoop=true
            //记录当前时间
            this.nowTime = Date.now()
            // 当前时间-上次执行时间如果大于diffTime,那么执行动画,并更新上次执行时间
            if(this.nowTime-this.lastTime > this.interval){
                this.lastTime = this.nowTime
                this.render();
            }
            this.rid=window.requestAnimationFrame(this.animLoop);
        },
        render() {
            if (this.flag == true) {
                if (this.left >= this.max-this.step) {
                    this.flag = false
                }
                this.left+=this.step
            } else {
                if (this.left <= 0+this.step) {
                    this.flag = true
                }
                this.left-=this.step
            }
        },
        start(){
            this.initInterval()
            this.animLoop()
        },
        stop(){
            cancelAnimationFrame(this.rid)
            this.initInterval()
        },
        add(){
            this.interval=this.interval/2
        },
        sub(){
            this.interval=this.interval*2
        }
    },
};
</script>

<style scoped>
.box{
    border:1px solid #f00;
    position: absolute;
    width: 300px;
    height: 100px;
    box-sizing: border-box;
    left: 30px;
    top:30px;
    z-index: 1;
}
.elem {
    width: 100px;
    height: 100px;
    background: lightgreen;
    position: absolute;
    left: 0;
    top: 0;
}
.btns{
    position: absolute;
    top: 150px;
}
</style>

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值