• 用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。

  • 相关阅读:
    捋一下Redis
    docker 的简单操作
    opencv的级联分类器(mac)
    python日常
    pip安装显示 is not a supported wheel on this platform.
    字节流与字符流的区别详解
    请求转发和重定向的区别及应用场景分析
    Eclipse的快捷键使用总结
    Eclipse给方法或者类添加自动注释
    IntelliJ IDEA 连接数据库 详细过程
  • 原文地址:https://www.cnblogs.com/lbliubinlb/p/4754270.html
Copyright © 2020-2023  润新知