fadeIn:function(speed,till){
speed = speed !== undefined ? speed : 400;
speed = typeof speed === 'number' ? speed : speed == "slow" ? 600 : speed == "fast" ? 200 : speed !== 'slow' || speed!== 'fast' ? 400 : 400;
var opc = window.getComputedStyle(this[0]).opacity;
var element = this[0];
var add = 100 / speed;
till = till !== undefined ? till : 1;
element.style.display="block";
var timer = (function a() {
if (opc >= till ){
element.style.opacity = 1;
clearInterval(timer);
return false;
}
if(browser[3] == 'MSIE' && Number(browser[4]) < 9 ){
add = 10000 / speed;
element.style.filter = 'alpha(opacity="' + (opc+ add) + '")';
}
element.style.opacity = opc;
opc = opc + add; // code here where addition starts
setTimeout(a, 50);
})();
},
上記の関数は、コースを正しく実行しません。JavaScript は浮動小数を正しく追加しないためです。ということで、いろいろな方法を試した...
opc = (opc * 100) + (add * 100) / 100;
また、これにより10進数が得られるため、ハックを試みましたが、実際には何があっても整数が得られます。
opc = "."+parseInt((opc * 100) + (add * 100) / 100,10);
上記の何が問題なのかは、文字列に変わり、うまくいかないことだと思いますが。したがって、問題は、これが非常に必要であるため、小数をどのようにインクリメントするかです。
例
0.001 - 0.002 - 0.003 - 0.004 etc