0
  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;

还尝试了一个 close hack,因为这给了我我的十进制数,上面给了我一个整数,无论​​如何。

 opc = "."+parseInt((opc * 100) + (add * 100) / 100,10);

虽然我相信上面的问题是它变成了一个字符串并且只是没有切割。所以问题是我如何增加小数,因为这是非常必要的。

例子

  0.001 - 0.002 - 0.003 - 0.004 etc 
4

1 回答 1

1

JavaScript 可以很好地添加浮点数。
可能您的操作数之一不是浮点数。

引用 JS 书籍: JavaScript 有一个单一的数字类型。在内部,它表示为 64 位浮点数,与 Java 的 double 相同。与大多数其他编程语言不同,没有单独的整数类型,因此 1 和 1.0 是相同的值。

我会尝试调试代码,然后查看哪些值是字符串(或不是数字),然后使用parseFloat函数解析它们。

于 2014-01-16T00:10:41.557 回答