对setInterval在火狐和chrome切换标签产生奇怪的效果之探索,与解决方案!
在上一篇文章: 觉得猪八戒网左下角的文字滚动,效果不错,自己摸索了一下,以自己的方法实现了!
就有这种效果,不过影响不大。Demo的影响就大了!
网上也有人出现过这样的问题看下面的帖子地址:
讨论的人很多,但没给出答案来。
怎么想都想不明白!
今天,突然茅塞顿开,可能是线程的概念,但是具体原因还是不明白,希望有人了解其原应告知,非常感激!
Demo 中黑色的Div是不受浏览器标签切换影响的
而红色的Div会受到影响。
HTML:
代码如下:
<div id="move" style="position: absolute; width: 100px; height: 100px; top: 0pt; left: 0pt; background: none repeat scroll 0% 0% #000000; z-index: 999; color: #ffffff;">我不受浏览器标签切换影响!Hoooo</div> <div id="move2" style="position: absolute; width: 100px; height: 100px; top: 0pt; left: 0pt; background: none repeat scroll 0% 0% red; z-index: 999; color: #ffffff;">我受浏览器标签切换影响!5555</div>
javascript:
代码如下:
(function(){ var elem = Meng.getId('move'), elem2 = Meng.getId('move2'), pos = Meng.getElemViewPosition(elem), view = Meng.getBrowserView(), //灰块运动函数 move = function(){ var t1 = Meng.animate(elem,{top:0,left:0},{top:view.height-100,left:view.width-100},3000,function(){ var t2 = Meng.animate(elem,{left:view.width-100},{left:100-view.width},3000,function(){ var t3 = Meng.animate(elem,{top:view.height-100},{top:100-view.height},3000,function(){ move();//确定t3运动完后,我再回调move()函数。 }); }); }); }; move(); // 红块运动函数 Meng.setStyle(elem2,{top:0,left:(view.width-100)+'px'}); var move2 = function(){ var t1 = Meng.animate(elem2,{top:0,left:view.width-100},{top:view.height-100,left:100-view.width},3000,function(){ var t2 = Meng.animate(elem2,{top:view.height-100},{top:100-view.height},3000,function(){ var t3 = Meng.animate(elem2,{left:0},{left:view.width-100},3000,function(){ }); }); }); }; move2(); setInterval(function(){move2();},9050); // 红块运动函数 })();
相关推荐
angqiuli 2020-05-16
弱思 2020-04-20
nankangren 2019-11-19
jiangbo0 2019-09-08
Luffyying 2016-05-11
hyv 2016-02-19
逆风飞舞0 2015-12-24
xaoyege 2019-06-27
崔博伦一路有你 2014-08-06
nmgxzm00 2014-04-28
itSeven 2012-12-18
83500391 2012-04-19
愚盦 2011-12-03
zhangmingming 2011-09-18
Tomhsfreestyle 2011-08-20
努力的zhiyi 2011-07-15
CXPOwen 2017-10-15
yzxlemon 2017-02-13