为了账号安全,请及时绑定邮箱和手机立即绑定

JS动画效果

vivian Web前端工程师
难度初级
时长 2小时 8分
学习人数
综合评分9.60
537人评价 查看评价
9.8 内容实用
9.6 简洁易懂
9.4 逻辑清晰

最新回答 / 传说中的小白龙
想了半天!终于知道了!跟我一样的小伙伴不明白的快点进来看!搞了半天,是javascript的问题,js里浮点数运算有一些小问题.具体情况你们加载这段代码就明白了.真是巨坑无比!<...code...>

最赞回答 / darcygail
兄台,这里的话。。多用几个计时器开销不是也很大么,这里的速度为0你把它当做判断条件就好了呀。其实我觉得效果比你想的那个好
其实从原理上来想就很容易知道为什么了。定义flag主要目的是要达到三个都为true时,才清掉计时器。也就是说,只要有一个为false就不清,老师的思路也是这样,但老师忽略忘记了变量复位。
而变量复位的位置放在哪?当然是三次move都执行完之后,若为false就复位,并且再次判断。所以这个复位必然是放在定时器里面,for-in外面。
再接着考虑一下清除定时器的位置放在哪,如果在for-in里面,当第一个move为true时,由于变量复位了,后面的move都不会执行。
只有清除的位置放在for-in外面,同时又在复位之前,这样就是说三次运动结束后,再来判断是否清除定时器。
希望我解释清楚了~
老师讲的真不错 点个赞

已采纳回答 / 不再热情似火
 flag放在函数外面也行,但是每次执行都必须初始化 flag 为 true,其次,flag 的 初始化 必须放在 for in 循环上面(不管你在哪定义flag)。 因为是for in 循环,参数达到目标之后,确实不执行你说的 icur != json[changeType] ; 但是,其余的for 循环时,会对其他的元素进行这个判断 if (attr !== json[attr] ) ;如果不等,flag 就变成了false;你可能看错了一个地方,if(flag === true){.....} 是放...

已采纳回答 / Csunnnnn
思路上分析,可以肯定问题出现在条件判断上,即tmd == 0.3这个条件从来没成立过,实际上是永不成立,这是浮点数的锅。目前一切语言的浮点数计算都是近似计算,会精确到小数点16位以上。所以对于浮点数变量tmd来说,人为感觉是 tmd == 0.3的时候, tmd实际值则是 0.300000000000001之类的值,所以不等。想要看清tmd实际值,只需在 tmd = tmd - 0.1;这句话后面加alert(tmd),就看得一清二楚。

最新回答 / qq_安静时刻_0
是那个tmd == 0.3 的原因,你改成 tmd< 0.3最后就不会显示透明了,具体原因你可以在计时器中输出tmd的值看看你就明白了。
传入的是对象,不是json
speed不仅仅指的是移动,只是代表状态改变的快慢。
代码的封装做的很好,很给力!对于有一定基础但是缺乏经验的同学来说----那是灰常棒啊
老师把这句话写成了icur = parseFloat(getStyle(obj.attr))*100;半天没出来,应该是icur = parseFloat(getStyle(obj,attr))*100;
更新啊老师,

最新回答 / 高手之路
<...图片...>找到原因了 被自己坑死了
课程须知
1.您至少已经具备JavaSript的知识。2.您已经具备一些开发经验。
老师告诉你能学到什么?
1.使用定时器实现简单动画。2.如何一步步封装库。2.培养编程的思想。

微信扫码,参与3人拼团

意见反馈 帮助中心 APP下载
官方微信
友情提示:

您好,此课程属于迁移课程,您已购买该课程,无需重复购买,感谢您对慕课网的支持!

本次提问将花费2个积分

你的积分不足,无法发表

为什么扣积分?

本次提问将花费2个积分

继续发表请点击 "确定"

为什么扣积分?

举报

0/150
提交
取消