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

JS动画效果

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

已采纳回答 / mingttong
倒数第5行的obj.offsetWidth=obj.offsetWidth+speed+'px'; 改为 obj.style.width=obj.offsetWidth+speed+'px';就可以了。一开始我也搞不懂为什么,百度了一下,说是obj.offsetWidth是数值,而obj.style.width是字符串,所以在用obj.offsetWidth+speed+'px'改变宽度时应该赋值给obj.style.width.

已采纳回答 / 小爬虫8036
timer=setInterval();这里返回值给timer,这里clearInterval(timer)取消调用,总之你得定义一个timer吧,让它等于null只是给一个默认值,你直接定义var timer;也是可以的。

已采纳回答 / 风随依然
首先,尽量不要用onmousemove去实验,而是用onmouseover.其次,odiv1.offsetLef ==0      其中,offsetLef 书写错误,应为offsetLeft.最后,解决方案,在css部分加上body{margin: 0; padding: 0;}    可使计时器生效。

已采纳回答 / 从此浪迹天涯了无牵挂
你试一下把move.js里面的var flag = true;挪动到定时器里面。因为链式调用,如果调用结束第一个, if(icur !== json[attr]){ flag=false; } if(attr=='opacity'){ obj.style.filter='alpha(opacity:'+(icur+speed)+')'; obj.style.opacity = (icur+speed)/100; } else{ obj.style[att...

已采纳回答 / 風雨纏溪
parseInt是获取整数,而后面的oDiv.style.width是获取的在body下面标签里的格式,之前用oDiv.offsetLeft是直接获取style里的值,但是在style里如果给oDiv加上了边框,那么offsetLeft就不能准确获取left的值了,而是获取left+边框的值,这里的oDiv.style.width不会有这个问题,但是还是很麻烦,因此后来又封装了一个函数,也就是getStyle()函数function getStyle(obj,attr){ if(obj.currentSt...

已采纳回答 / 路漫漫兮2015
当(itarget-odiv.offsetLeft)/20=10/20=0.5PX时,oDiv.style.left = oDiv.offsetLeft+speed+'px';=190+0.5=190.5px,像素出现了小数程序无法执行下去。

已采纳回答 / sunfloweryll
定时器的函数写错了,<...图片...>

已采纳回答 / MoocChenWei
timer在这里需要为全局变量,在定时器前面加timer=,注意不能再加var,否则据就近原则,startMove函数中使用的timer就不是函数外部的全局变量了,就无法达到预期的效果~你试试看

已采纳回答 / qq_囿于平常_0
并不是所有数据都会出现小数点误差情况,老师也列举了好几个,不是就出现一个么。虽然误差小,但是加了总比不加合适

已采纳回答 / Ayra
27行sart2(this,400);中 sart2没有定义 你写错单词了 应该是 start2

已采纳回答 / 青鸟衔音
<style type="text/css"> *{ margin: 0; padding: 0; } #move{ width: 300px; margin: 10px auto; border: 1px solid #ccc; } #move a{ display: inline-block; width: 58px; height: 25px; border: 1px solid #ddd; border-radius: 3px; b...

已采纳回答 / 凝雨
obj.style[attr]是去取obj的样式中的某个属性,attr是变量。可以是height,可以是width。obj.style.attr是去取obj的样式中的attr属性,而实际上这个属性是不存在的,所以不行。还有 li1.onmouseout=function(){move(this,"widht",200)} 中的宽写错了

已采纳回答 / 天道总司
上传问题前建议自己认认真真仔仔细细的检查多遍。第51行!iTarget你打成了iIerget!这样运行的时候当然是找不到下面的iTarget的。

已采纳回答 / 天道总司
第51行<...code...>你写错了,中间是","。应该是<...code...>这样就没问题了
课程须知
1.您至少已经具备JavaSript的知识。2.您已经具备一些开发经验。
老师告诉你能学到什么?
1.使用定时器实现简单动画。2.如何一步步封装库。2.培养编程的思想。

微信扫码,参与3人拼团

微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号

友情提示:

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

本次提问将花费2个积分

你的积分不足,无法发表

为什么扣积分?

本次提问将花费2个积分

继续发表请点击 "确定"

为什么扣积分?

举报

0/150
提交
取消