这次给大家带来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图例:
setinterval图例:
存在即合理父子元素事件冒泡,需要先执行父元素,见示例3;
用户自定义的回调函数,通常在浏览器的默认动作之前触发,见示例4;
示例3:
<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:
<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简单兼容window.requestanimframe = (function(){
return window.requestanimationframe ||
window.webkitrequestanimationframe ||
window.mozrequestanimationframe ||
function( callback ){
window.settimeout(callback, 1000 / 60);
};
})();
相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!
推荐阅读:
js用正则判断出生日期
vue过滤器格式化方法详解
以上就是js动画定时器使用教程的详细内容。