zoukankan      html  css  js  c++  java
  • 用JS做计算的时候小数位不正常--Js中parseFloat()方法所产生的精度问题

     

    <script language="javascript">

    var a = "0.11";
    var b = "0.2801";
    var c = "1.002";


    var sum1 = parseFloat(a)+parseFloat(b)+parseFloat(c);
    var sum2 = (parseFloat(a)+parseFloat(b)+parseFloat(c)).toFixed(4)
    document.write("a+b+c="+sum1);
    document.write("<br/>")
    document.write("a+b+c="+sum2)


    </script>

    1.3921000000000001

    1.3921

    a,b,c相加本来为1.3921,但sum1得出的结果为:1.3921000000000001,显然不正确,通过toFixed(n)方法修正后,得到正确结果。

    js parsefloat parseint

    JavaScript提供了3个显式的类型转换函数,分别是eval()、parseInt()和parseFloat()。

    eval()函数:将字符串表达式转换成数字值。例如,语句total=eval("432.1*10")的结果是total=4321即将数值4321赋予total变量。

    parseInt()函数:把字符串转换成整数。返回是从字符串的第一个字符开始,如果字符不是以整数开头则返回0。parseInt()函数还可以转换十六进制数或十进制数。

    例如:parseInt("123xyz") 返回123,而parseInt("xyz")返回0。

    parseFloat()函数:类似于parseInt()函数,它返回字符串上包含的第一个浮点数。如果字符串不以有效浮点数开头,则返回0。

    例如:parseFloat("2.1e4xyz")返回21000;而parseFloat("xyz")返回0。

    JavaScript中parseFloat函数方法是返回由字符串转换得到的浮点数。 使用方法:

    parseFloat(numString)其中numString 参数是包含浮点数的字符串。JavaScript中parseFloat函数方法返回与 numString 中保存的数相等的数字表示。如果 numString 的前缀不能解释为浮点数,则返回 NaN (而不是数字)。

    parseFloat("abc") // 返回 NaN。 
    parseFloat("1.2abc") // 返回 1.2。

  • 相关阅读:
    CSS魔法堂:选择器及其优先级
    HTML5 placeholder实际应用经验分享及拓展
    WEBAPP开发技巧(手机网站开发注意事项)
    PhotoShop的10大误区
    django之搜索引擎功能实现
    django之使用git协作开发项目
    docker简单操作
    docker之container eb7a144fe8ce is using its referenced image 9b9cb95443b5
    django之动态轮播图技术的实现
    django之Model(数据表)的增删改查
  • 原文地址:https://www.cnblogs.com/lbliubinlb/p/4754270.html
Copyright © 2011-2022 走看看