全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

JavaScript requestAnimationFrame动画详解

进入web2.0时代,在网页中实现动画已经不再局限于一种方法

  • 你可以用CSS3的animattion+keyframes;
  • 你也可以用css3的transition;
  • 你还可以用通过在canvas上作图来实现动画,也可以借助jQuery动画相关的API方便地实现;
  • 当然最原始的你还可以使用window.setTimout()或者window.setInterval()通过不断更新元素的状态位置等来实现动画,前提是画面的更新频率要达到每秒60次才能让肉眼看到流畅的动画效果。

认识JavaScript requestAnimationFrame

首先我们来看一下它的源码
requestAnimationFrame on github

// Adapted from https://gist.github.com/paulirish/1579671 which derived from 
// http://paulirish.com/2011/requestanimationframe-for-smart-animating/
// http://my.opera.com/emoller/blog/2011/12/20/requestanimationframe-for-smart-er-animating

// requestAnimationFrame polyfill by Erik Möller.
// Fixes from Paul Irish, Tino Zijdel, Andrew Mao, Klemen Slavič, Darius Bacon

// MIT license

if (!Date.now)
 Date.now = function() { return new Date().getTime(); };

(function() {
 'use strict';

 var vendors = ['ms', 'moz', 'webkit', 'o'];
 //浏览器兼容
 for (var i = 0; i < vendors.length && !window.requestAnimationFrame; ++i) {
 //对于支持的浏览器直接统一接口
  var vp = vendors[i];
  window.requestAnimationFrame = window[vp+'RequestAnimationFrame'];
  window.cancelAnimationFrame = (window[vp+'CancelAnimationFrame']
         || window[vp+'CancelRequestAnimationFrame']);
 }
 if (/iP(ad|hone|od).*OS 6/.test(window.navigator.userAgent) // iOS6 is buggy
  || !window.requestAnimationFrame || !window.cancelAnimationFrame) {
  //对于不支持的浏览器退而使用setTimeout和clearTimeout
  var lastTime = 0;
  window.requestAnimationFrame = function(callback) {
   var now = Date.now();
   var nextTime = Math.max(lastTime + 16, now);
   return setTimeout(function() { callback(lastTime = nextTime); },
        nextTime - now);
  };
  window.cancelAnimationFrame = clearTimeout;
 }
}());

相信那一点点源码的阅读对大家都没有问题,就算读不懂也没关系,会调用api就可以了

requestAnimationFrame的优点

浏览器可以优化并行的动画动作,更合理的重新排列动作序列,并把能够合并的动作放在一个渲染周期内完成,从而呈现出更流畅的动画效果。比如,通过requestAnimationFrame(),JS动画能够和CSS动画/变换或SVG SMIL动画同步发生。另外,如果在一个浏览器标签页里运行一个动画,当这个标签页不可见时,浏览器会暂停它,这会减少CPU,内存的压力,节省电池电量。

用法示例:

function animate() {
  console.log("animation");
  window.requestAnimationFrame(animate);
 }
animate();

requestAnimationFrame(animate)是关键,它为要执行的函数设置了动画,所以浏览器控制台会一直执行animate()函数。

浏览器兼容性

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# JavaScript  # requestAnimationFrame  # 动画  # 深入理解requestAnimationFrame的动画循环  # requestAnimationFrame使用示例详解  # 一文详解requestAnimationFrame请求动画帧  # 可以用  # 你还  # 放在  # 大家都  # 也没  # 你也  # 不懂  # 能让  # 不支持  # 可以使用  # 那一  # 来实现  # 并把  # 这会  # 不断更新  # 局限于  # 大家多多  # 它为  # 就可以  # 等来 


相关文章: 网站图片在线制作软件,怎么在图片上做链接?  常州企业建站如何选择最佳模板?  再谈Python中的字符串与字符编码(推荐)  如何将凡科建站内容保存为本地文件?  已有域名建站全流程解析:网站搭建步骤与建站工具选择  如何快速生成专业多端适配建站电话?    如何在宝塔面板中修改默认建站目录?  完全自定义免费建站平台:主题模板在线生成一站式服务  Avalonia如何实现跨窗口通信 Avalonia窗口间数据传递  网站制作网站,深圳做网站哪家比较好?  长春网站建设制作公司,长春的网络公司怎么样主要是能做网站的?  香港服务器如何优化才能显著提升网站加载速度?  实例解析angularjs的filter过滤器  免费视频制作网站,更新又快又好的免费电影网站?  如何用好域名打造高点击率的自主建站?  高端智能建站公司优选:品牌定制与SEO优化一站式服务  建站之星在线版空间:自助建站+智能模板一键生成方案  如何通过虚拟主机空间快速建站?  如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?  Android滚轮选择时间控件使用详解  如何在七牛云存储上搭建网站并设置自定义域名?  nginx修改上传文件大小限制的方法  如何在香港免费服务器上快速搭建网站?  h5在线制作网站电脑版下载,h5网页制作软件?  企业网站制作费用多少,企业网站空间一般需要多大,费用是多少?  免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?  平台云上自助建站如何快速打造专业网站?  建站之星价格显示格式升级,你的预算足够吗?  建站之星北京办公室:智能建站系统与小程序生成方案解析  如何快速搭建二级域名独立网站?  如何高效生成建站之星成品网站源码?  如何在景安云服务器上绑定域名并配置虚拟主机?  专业制作网站的公司哪家好,建立一个公司网站的费用.有哪些部分,分别要多少钱?  零服务器AI建站解决方案:快速部署与云端平台低成本实践  简历在线制作网站免费,免费下载个人简历的网站是哪些?  浅析上传头像示例及其注意事项  如何在沈阳梯子盘古建站优化SEO排名与功能模块?  ,石家庄四十八中学官网?  如何在万网自助建站中设置域名及备案?  网站制作壁纸教程视频,电脑壁纸网站?  建站主机选购指南:核心配置与性价比推荐解析  如何撰写建站申请书?关键要点有哪些?  如何选择适配移动端的WAP自助建站平台?  建站VPS能否同时实现高效与安全翻墙?  广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?  北京专业网站制作设计师招聘,北京白云观官方网站?  网站app免费制作软件,能免费看各大网站视频的手机app?  高防服务器:AI智能防御DDoS攻击与数据安全保障  微网站制作教程,我微信里的网站怎么才能复制到浏览器里? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。