首页 > web前端 > js教程 > js动画定时器使用教程

js动画定时器使用教程

php中世界最好的语言
发布: 2018-05-09 09:44:03
原创
1587 人浏览过

这次给大家带来js动画定时器使用教程,js动画定时器使用的注意事项有哪些,下面就是实战案例,一起来看一下。

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

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

定时器

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

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

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

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

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

认识setTimeout

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

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

this指向问题,见示例2;

返回值是个整数;

clearTimeout(timer)取消定时器;

setInterval,clearInterval同上;

示例1:

1

2

3

setTimeout(function(a,b){ 

 console.log(a+b); 

},1000,1,1);

登录后复制

示例2:

1

2

3

4

5

6

7

8

9

var a = 0;

function foo(){

 console.log(this.a);

};

var obj = {

 a : 2,

 foo:foo

}

setTimeout(obj.foo,100);

登录后复制

运行机制

示例:

1

2

3

4

setTimeout(function(){ 

 console.log(1); 

}); 

console.log(0);

登录后复制

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

setTimeout图例:

setInterval图例:

存在即合理

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

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

示例3:

1

2

3

4

5

6

7

8

9

10

11

<p id="myp" style="height: 100px;width: 100px;background-color: pink;"></p>

<script>

myp.onclick = function(){

 setTimeout(function(){

  alert(0);

 })

}

document.onclick = function(){

 alert(1);

}

</script>

登录后复制

示例4:

1

2

3

4

5

6

7

8

<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示例

raf简单兼容

1

2

3

4

5

6

7

8

window.requestAnimFrame = (function(){ 

 return window.requestAnimationFrame || 

   window.webkitRequestAnimationFrame ||   

   window.mozRequestAnimationFrame || 

   function( callback ){  

    window.setTimeout(callback, 1000 / 60);

    };

  })();

登录后复制

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

JS用正则判断出生日期

Vue过滤器格式化方法详解

以上是js动画定时器使用教程的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
怎么实现 JavaScript点与圆的位置关系
来自于 1970-01-01 08:00:00
0
0
0
JavaScript钩子函数是什么?
来自于 1970-01-01 08:00:00
0
0
0
c++ 调用javascript
来自于 1970-01-01 08:00:00
0
0
0
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板