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

认识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小时内与您取得联系。