服了,有没有人遇到了就是链式代码只执行了第一个函数,函数内部的函数都不执行?比如说给一个div先把宽度从200增加到400,这是执行一次的方法对吧,宽度增加完了以后再把高度增加到500,但是这里我遇到的问题就是,第一次执行,宽度增加了,但是高度却不被执行,也就是内部的方法代码并没执行,调试发现直接被跳过了。。原来我在判断有没有方法的时候也就是if(fn){}这里,我把这个判断语句写在了clearInterval(timer)前面去了。。。我靠,就这样,代码没报错,到处去搜去问。。最后把位置颠倒一下就好了。。也就是把clearInterval这句停止定时器的代码先于if(fn)执行。。。。
2018-05-02
已采纳回答 / 夜莺_47
如果speed是正数的话,向上取整,比如0.5取到1才有意义,毕竟0.5是有速度的而不是0;如果speed是负数的话,向下取整,比如-0.5取到-1,-0.5会进行反向运动从而达到停止条件iTarget == icur,如果为负数向上取整则Math.ceil(-0.5) = -0则达不到iTarget == icur。因此负数要像下取整Math.floor()
2018-05-02
已采纳回答 / 慕数据9255373
当你多次触碰时,上一次的定时器timer被
var timer=null;重新赋值了(即timer这个定时器的对象找不到了),导致clearInterval(timer),起不了作用。应该将var timer=null;写在函数的外面
2018-04-26
最新回答 / qq_零_137
else { icur = Math.round(parseFloat(getStyle(obj, attr))); }这句错了,应该是else {icur = parseInt(getStyle(obj, attr)); //整数型}
2018-04-06
最新回答 / qq_long妹_0
原因是style.width仅能返回以style方式定义的内部样式表的width属性值,故第24行代码需修改为<div id="div1" style="width: 200px"></div>,再把原先的width样式删除即可。
2018-04-06
最赞回答 / hellf
跟css中的{margin:0;padding:0;} 没有关系,你的代码中,判断offsetLeft 的条件改为: if(odiv.offsetLeft>=0) 它就停下来了 ,因为在不断移动的过程中,不一定有0这个值还有一个问题,进入startMove()时, 需要先清除一下定时器,目的是保证同时只有一个定时器在运行,你的代码还给你,就改了两个地方:<!DOCTYPE html><html><head><title>动画</title>...
2018-03-23
关于flag定义时的三个位置问题
1flag位于for循环的内部
flag在里面的话,只要flag未设false,并立刻跳出for循环,就导致定时器的终止,即对于解决老师提到的宽度201问题毫无帮助
2flag位于for外部,定时器内部
正确,在几个属性值到达自己的目标值前,不会提前终止定时器。
3flag位于定时器外,function函数内
可以运行,但有问题。
flag没用,只是因为没有关闭定时器,所以三个属性都到达了自己的目标值,与flag没有关系
检验方法:跳出for循环后的if语句内部加入alert(flag),最好放在清除定时器前,你就能看到,if内部并没有执行,网页中也没有提示框
1flag位于for循环的内部
flag在里面的话,只要flag未设false,并立刻跳出for循环,就导致定时器的终止,即对于解决老师提到的宽度201问题毫无帮助
2flag位于for外部,定时器内部
正确,在几个属性值到达自己的目标值前,不会提前终止定时器。
3flag位于定时器外,function函数内
可以运行,但有问题。
flag没用,只是因为没有关闭定时器,所以三个属性都到达了自己的目标值,与flag没有关系
检验方法:跳出for循环后的if语句内部加入alert(flag),最好放在清除定时器前,你就能看到,if内部并没有执行,网页中也没有提示框
2018-03-18