繁体   English   中英

Javascript返回NaN

[英]Javascript returning NaN

每次客户输入数量时,我都会尝试显示小计。 但是,当我循环输入时,我得到一个NaN作为总数。 我相信它可能是我在我的脚本中声明subtotal变量的方式,但我之前没有遇到过这个:

$('.item-qty input').bind('keyup', function(){

   var subtotal = 0.0;

   $('.item-qty input').each(function(){
      var class = $(this).attr('id');
      var qty = $(this).val();                     
      var price = $('.'+class).html();

      price = parseFloat(price);
      qty = parseInt(qty);
      subtotal = subtotal + (price * qty);
   });

   $('.subtotal input').val(subtotal);
});

如果字符串的第一个字符无法转换为数字,则parseFloatparseInt可以返回NaN

所以,我会像这样保护它( NaN是一个值):

price = parseFloat(price) || 0;
qty = parseInt(qty, 10) || 0;

对值为NaN数字的算术运算几乎总是导致NaNNaN + 5将导致NaN 。)这意味着,如果只有一个输入无法被parseFloatparseInt解析,那么您当前的代码最终将为此计算NaN小计。


它已在评论中提及(主要由Felix提及),但我认为值得强调,因为这些是重要的问题:

  • 始终将radix参数传递给parseInt函数;
  • 不要将class用于变量名:它是保留(未使用但保留)的关键字;
  • 除非你以美分计算,否则不要指望小计是完全准确的

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM