css3-帧动画实现和优化

参考文章
实现帧动画好多种方式,如css3,gif动图,视频,js帧动画,很多做实验比较这几种方式的优劣,最终还是推荐了css3动画

我就直接说实现方式把

1 css3代码
html:

<div  class="loadingMask"><div class="loadingMask-img"></div></div>
css:

  
.loadingMask{
  position: absolute;
  width: 540px;
  height: 960px;
  overflow: hidden;
}
.loadingMask-img{
  content: '';
  width: 7560px;
  height: 960px;
  display: block;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  background-image: url(img/1.png);
  background-position: center;
  background-repeat: no-repeat;
  background-size: auto;
  animation: aniVip 2s steps(14,start) 0.1s infinity ;
  }

@keyframes aniVip {
    0%{transform: translate3d(0,0,0);opacity: 1;}
    50%{opacity: 0.8;}  
    100%{transform: translate3d(-7560px,0,0);opacity: 0;}
}

2animate()
var animation = element.animate(keyframes, options);
keyframes 关键帧

一个对象,代表关键帧的一个集合

options 可选项代表动画持续时间的整形数字 (以毫秒为单位), 或者一个包含一个或多个时间属性的对象

例如上面的动画用函数写就是:

    let bg=document.getElementById("loadingMask-img") as HTMLElement;
    let myAni=bg.animate([
      {transform: 'translate3d(0,0,0)',opacity:1},  
      {opacity:0.8},  
      {transform: 'translate3d(-7560px,0,0)',opacity:0}
    ],{
      duration:2000,
      delay:100,
      easing:'steps(14,start)',
      iterations:1
    })
    myAni.onfinish=()=>{
      console.log("finish")
      this.showGuide=false;  
    }

这么好用的东西当然兼容性很差了啊,所以你要想用这个函数,需要使用https://github.com/web-animations/web-animations-js

参考文章:

强大的CSS3/JS:帧动画的多种实现方式与性能对比
CSS3动画卡顿性能优化解决方案
借助Web Animations API实现JS keyframes动画
标签:animate、css3、keyframes animate

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值