这是我的javascript代码:
var dsum = 0.0;
$.each($("#Report tbody tr"), function () {
var x = 0.0;
if ($(this).find("td:eq(3) div").html() != " ")
x = parseFloat($(this).find("td:eq(3) div").html().replace(/,/g, ""));
dsum += x;
});
var csum = 0.0;
$.each($("#Report tbody tr"), function () {
var x = 0.0;
if ($(this).find("td:eq(4) div").html() != " ")
x = parseFloat($(this).find("td:eq(4) div").html().replace(/,/g, ""));
csum += x;
});
var lastEvenRow=$("#Report").find("tr:last").hasClass('erow');
$("<tr id='LastRow'><td colspan='3' style='border-top: 1px solid #DDDDDD;'><div style='padding:5px;text-align:right;'>Total :</div></td><td style='text-align:center;height:22px;border-top: 1px solid #DDDDDD;'><div style='padding:5px;'>" + dsum.toString(10).replace( /(\d)(?=(\d\d\d)+(?!\d))/g , "$1,") + "</div></td><td style='text-align:center;border-top: 1px solid #DDDDDD;'><div style='padding:5px;'>" + csum.toString(10).replace( /(\d)(?=(\d\d\d)+(?!\d))/g , "$1,") + "</div></td><td style='text-align:center;border-top: 0px solid #DDDDDD;'><div style='padding:5px;border-top: 1px solid #DDDDDD;'>" + (dsum > csum ? (dsum - csum).toString(10).replace( /(\d)(?=(\d\d\d)+(?!\d))/g , "$1,") : " ") + "</div></td><td style='text-align:center;'><div style='padding:5px;'>" + (csum >= dsum ? (csum - dsum).toString(10).replace( /(\d)(?=(\d\d\d)+(?!\d))/g , "$1,") : " ") + "</div></td></tr>").appendTo("#Report tbody");
if(lastEvenRow==false)
$("#LastRow").addClass("erow");
正如我在图片中提到的,我认为结果必须是104,889.01,但正如您所见,它是不正确的值
那里有什么身体可以帮助我吗? 抱歉我的英语语法不好(我是英语新手)
UPDATE1 :
1318114.01 - 1213225必须是104889.01,为什么javascript返回104889.01000000001?!!
答案 0 :(得分:2)
这是因为它适用于从二进制到十进制的转换,然后我们有aproximations,其结果是大浮点数。参见:
var i = 1;//1
i += .1;//1.1
i += .1;//1.2000000000000002
您可以尝试自己的近似:
var result = Math.round((1318114.01-1213225)*1000)/1000;