您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息
免费发信息
三六零分类信息网 > 延边分类信息网,免费分类信息发布

js动画定时器使用教程

2024/6/2 0:53:25发布59次查看
这次给大家带来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动画定时器使用教程的详细内容。
延边分类信息网,免费分类信息发布

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录