為什么這段代碼有Bug
function?MoveModelFn(obj,json,fn){
//var?flag=true;
clearInterval(obj.timer);
obj.timer=setInterval(function(){
for(var?attr?in?json){
//?判斷屬性
var?icur=0;
if?(attr=='opacity')?{
icur?=Math.round(parseFloat(getStyle(obj,attr))*100);
}else{
icur=parseInt(getStyle(obj,attr));
}
//設置速度
var?speed=(json[attr]-icur)/10;
var?speed=speed>0?Math.ceil(speed):Math.floor(speed);
//?判斷停止
if(icur!=json[attr]){
//flag=false;
if?(attr=='opacity')?{
obj.style.filter='alpha(opacity:'+(icur+speed)+')';//icur原始值+變化值speed
obj.style.opacity=(icur+speed)/100;
}else{
obj.style[attr]=icur+speed+"px";
}
}else {
clearInterval(obj.timer);
//?回調函數
if?(fn)?{
fn();
}
}
}
},30)如果不設立標桿。用if()else 有有bug
2016-04-20
首先,else要放在for循環外面,否則,一旦某一個attr達到目標值,即icur==json[attr]成立,就完成了else的判斷.會運行else的代碼.
其次,設立標桿的目的是為了方便取值,為else里面的代碼進行成立與否的判斷!!在for循環里面,程序會進行分次判斷,有幾個attr就會判斷幾次,只要有一個false,返回值就是false,如果不設立標桿,會出現某次是true,某次是false的結果,無法進行后面的else判斷.
即只要有一個attr達到目標值,icur==json[attr]的等式就會成立(就是說這個等式無法作為else執行判斷的依據),也就是else的代碼就會執行,計時器就會清除.
2016-04-18
沒問題呀