定义变量flag的时候,位置应该是放在setInterval()这个计时器了。解决了调用回调函数与目标值无法完全匹配的Bug,至此,这个运动框架已经相对完美。问答里已分享。
2015-09-10
3.最后来说说我们这个“完美”框架。如果你百分之一百的复制老师的这个完美代码,你还是会发现,根本就无法执行这个回调函数!然后评论里的方法是这样的:
if(json[attr] != curStyle){flag= false;}else{flag=true;}
这样操作之后,首先在逻辑上也不错,也确实解决了无法执行回调函数的bug,但是!!!这样操作之后,会发现,物体运动达不到完全吻合的目标值,会出现一丢丢误差。
if(json[attr] != curStyle){flag= false;}else{flag=true;}
这样操作之后,首先在逻辑上也不错,也确实解决了无法执行回调函数的bug,但是!!!这样操作之后,会发现,物体运动达不到完全吻合的目标值,会出现一丢丢误差。
2015-09-10
2.关于opactiy这节。IE浏览器下。因为样式表里,filter:alpha(opacity=#);
所以定义startMove这个函数,最后返回值应该是:obj.style.filter= 'alpha(opacity='+(curStyle+rate)+')';
老师写成了 obj.style.filter="alpha(opacity:"+(cur+speed)+")"。所以你在IE下肯定是执行不了的!
所以定义startMove这个函数,最后返回值应该是:obj.style.filter= 'alpha(opacity='+(curStyle+rate)+')';
老师写成了 obj.style.filter="alpha(opacity:"+(cur+speed)+")"。所以你在IE下肯定是执行不了的!
2015-09-10
首先作为一个新手,感谢老师的分享。但是,我这里加了一个但是,你就知道话锋一转了,我是来吐槽的。只要有一点纰漏,整个框架就无法执行了。对新手来说,这感觉让我很绝望。下面总结一下小bug。
1.链式运动这节,假设DOM有多个元素。getLi=documen.getElementsByTagName('li');然后我们用startMove(this,属性,目标值,function(){startMove(this,属性,目标值)}),执行第一个函数的时候是没有问题的,但是当执行回调函数的时候就报错了。因为这个回调函数this的值域变了。评论里用的方法是定义一个变量=this,然后引用这个变量。
1.链式运动这节,假设DOM有多个元素。getLi=documen.getElementsByTagName('li');然后我们用startMove(this,属性,目标值,function(){startMove(this,属性,目标值)}),执行第一个函数的时候是没有问题的,但是当执行回调函数的时候就报错了。因为这个回调函数this的值域变了。评论里用的方法是定义一个变量=this,然后引用这个变量。
2015-09-10