温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

JS如何实现动画定时器

发布时间:2021-08-17 14:10:24 来源:亿速云 阅读:147 作者:小新 栏目:web开发

这篇文章主要为大家展示了“JS如何实现动画定时器”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JS如何实现动画定时器”这篇文章吧。

广义说:一切通过js改变的视觉呈现都叫动画;例如,按钮,链接等元素交互反馈。

狭义说:通过定时器连续调用js函数进行元素属性改变产生的视觉动画效果。

定时器

定时器是JavaScript动画的核心技术;

setTimeout(),setInterval()是大家熟知的,以前经常使用的;

一般都是做些辅助性,锦上添花的事;

细心的人可能会发现一个现象,从其他标签页切换到有循环动画页面会有卡顿和急速帧切换现象;

问题就在于他们的内在运行机制;

认识setTimeout

第一个参数推荐用函数形式,字符串形式会两次解析,还有eval一样的问题;

不止两个参数,可以更多,见示例1;

this指向问题,见示例2;

返回值是个整数;

clearTimeout(timer)取消定时器;

setInterval,clearInterval同上;

示例1:

setTimeout(function(a,b){   console.log(a+b);  },1000,1,1);

示例2:

var a = 0; function foo(){  console.log(this.a); }; var obj = {  a : 2,  foo:foo } setTimeout(obj.foo,100);

运行机制

示例:

setTimeout(function(){   console.log(1);  });  console.log(0);

原因:加入队列,阻塞执行。

setTimeout图例:

JS如何实现动画定时器

setInterval图例:

JS如何实现动画定时器

存在即合理

父子元素事件冒泡,需要先执行父元素,见示例3;

用户自定义的回调函数,通常在浏览器的默认动作之前触发,见示例4;

示例3:

<div id="myDiv" ></div> <script> myDiv.onclick = function(){  setTimeout(function(){   alert(0);  }) } document.onclick = function(){  alert(1); } </script>

示例4:

<input type="text" id="myInput"> <script> myInput.onkeypress = function(event) {  setTimeout(function(){   myInput.value = myInput.value.toUpperCase();  }); } </script>

认识requestAnimationFrame

用法与setTimeout类似,只是不需要时间参数;

机制完全不同:

1,setTimeout是异步操作,加入任务队列( event loop ),当js引擎线程中同步代码执行完才会从任务队列中取出执行;

2,raf是用户代理(浏览器)专门针对动画开发的接口,用户代理会以合适的频率进行动画帧更新(一般同显示器刷新频率,1000/60ms),在隐藏或者非活动页面会停止帧更新,节省CPU资源;

3,raf示例

JS如何实现动画定时器

raf简单兼容

window.requestAnimFrame = (function(){   return window.requestAnimationFrame ||     window.webkitRequestAnimationFrame ||       window.mozRequestAnimationFrame ||     function( callback ){       window.setTimeout(callback, 1000 / 60);     };   })();

以上是“JS如何实现动画定时器”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

向AI问一下细节
推荐阅读:
  1. js定时器
  2. js定时器案例

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

js
AI