返回顶部
首页 > 资讯 > 前端开发 > node.js >javascript小数相减出现一长串小数位数的原因是什么
  • 927
分享到

javascript小数相减出现一长串小数位数的原因是什么

2024-04-02 19:04:59 927人浏览 薄情痞子
摘要

本篇内容介绍了“javascript小数相减出现一长串小数位数的原因是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,

本篇内容介绍了“javascript小数相减出现一长串小数位数的原因是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

原因:整数型会自动转换成整型来计算,小数则直接转成double型进行计算;而double型需要精确到小数点后15位,因而javascript小数相减会出现一长串的小数位数。

教程操作环境:windows7系统、javascript1.8.5版、Dell G3电脑。

javascript小数相减会出现一长串的小数位数的原因

<script>
var a='38.8';
var b='6.8';
alert(parseFloat(a)-parseFloat(b));
var a=134.22;
var b=6;
alert(a*b);
</script>

以上代码为什么产生一长串小数位出来,虽然比较精确,可没必要呀。

这个和数据结构有关系,整数型自动转换成正型计算,小数型直接转成double型计算。这是在内存中运算的时候必须这样,你该知道计算机只认识0和1吧,具体的就是浮点精准度的问题。

  • float 精确到小数点后7位

  • double 精确到小数点后15位

javascript:document.write( (11.3-10.1).toFixed(2) )

toFixed()方法不仅仅截去多余的小数位,同时它还根据截取位置的下一个小数位进行四舍五入。例如,对于数值10.739,截取到小数点后的两位数,结果将是10.74。而对于数值10.732,截取到小数点后的两位数,结果将是10.73。

注意,在JavaScript中我们只能截取小数点之后0位~20位的小数。

toFixed()方法仅被高版本的浏览器所支持,所以在使用之前最好先检查一下浏览器是否支持该方法,检查的代码如下所示:

var varNumber = 22.234;
 
if (varNumber.toFixed)
{
varNumber = varNumber.toFixed(2);
}
else //浏览器不支持toFixed()就使用其他方法
{
var div = Math.pow(10,2);
varNumber = Math.round(varNumber * div) / div;
}

这样可以解决,但你想问,怎么可能多出这么小数点出来。

为什么会出现如此无法理解的答案?

Google了一下,发现原来这是JavaScript浮点运算的一个bug。

比如:7*0.8 JavaScript算出来就是:5.6000000000000005

网上找到了一些解决办法,就是重新写了一些浮点运算的函数。

下面就把这些方法摘录下来,以供遇到同样问题的朋友参考:

程序代码

//除法函数,用来得到精确的除法结果
//说明:javascript的除法结果会有误差,在两个浮点数相除的时候会比较明显。这个函数返回较为精确的除法结果。
//调用:accDiv(arg1,arg2)
//返回值:arg1除以arg2的精确结果
 
function accDiv(arg1,arg2){
var t1=0,t2=0,r1,r2;
try{t1=arg1.toString().split(".")[1].length}catch(e){}
try{t2=arg2.toString().split(".")[1].length}catch(e){}
with(Math){
r1=Number(arg1.toString().replace(".",""))
r2=Number(arg2.toString().replace(".",""))
return (r1/r2)*pow(10,t2-t1);
}
}
//给Number类型增加一个div方法,调用起来更加方便。
Number.prototype.div = function (arg){
return accDiv(this, arg);
}
//乘法函数,用来得到精确的乘法结果
//说明:javascript的乘法结果会有误差,在两个浮点数相乘的时候会比较明显。这个函数返回较为精确的乘法结果。
//调用:accMul(arg1,arg2)
//返回值:arg1乘以arg2的精确结果
function accMul(arg1,arg2)
{
var m=0,s1=arg1.toString(),s2=arg2.toString();
try{m+=s1.split(".")[1].length}catch(e){}
try{m+=s2.split(".")[1].length}catch(e){}
return Number(s1.replace(".",""))*Number(s2.replace(".",""))/Math.pow(10,m)
}
//给Number类型增加一个mul方法,调用起来更加方便。
Number.prototype.mul = function (arg){
return accMul(arg, this);
}
//加法函数,用来得到精确的加法结果
//说明:javascript的加法结果会有误差,在两个浮点数相加的时候会比较明显。这个函数返回较为精确的加法结果。
//调用:accAdd(arg1,arg2)
//返回值:arg1加上arg2的精确结果
function accAdd(arg1,arg2){
var r1,r2,m;
try{r1=arg1.toString().split(".")[1].length}catch(e){r1=0}
try{r2=arg2.toString().split(".")[1].length}catch(e){r2=0}
m=Math.pow(10,Math.max(r1,r2))
return (arg1*m+arg2*m)/m
}
//给Number类型增加一个add方法,调用起来更加方便。
Number.prototype.add = function (arg){
return accAdd(arg,this);
}

在你要用的地方包含这些函数,然后调用它来计算就可以了。

比如你要计算:7*0.8 ,则改成 (7).mul(8)

其它运算类似,就可以得到比较精确的结果。

“javascript小数相减出现一长串小数位数的原因是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: javascript小数相减出现一长串小数位数的原因是什么

本文链接: https://lsjlt.com/news/66242.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • javascript小数相减出现一长串小数位数的原因是什么
    本篇内容介绍了“javascript小数相减出现一长串小数位数的原因是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,...
    99+
    2024-04-02
  • JS中小数相加不精确的原因是什么
    这篇文章主要介绍“JS中小数相加不精确的原因是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“JS中小数相加不精确的原因是什么”文章能帮助大家解决问题。Javascript中小数相加的问题在Jav...
    99+
    2023-07-06
  • php相同的数不相等是什么原因
    这篇文章主要为大家展示了php相同的数不相等是什么原因,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带大家一起来研究并学习一下“php相同的数不相等是什么原因”这篇文章吧。当php相同的数判断出不相等时,说明它们虽然数值一样...
    99+
    2023-06-14
  • MySQL 中一位最小的数据类型是什么?
    一位的最小数据类型可以是bit(1)。语法如下 -yourColumnName bit(1)为了理解上述语法,让我们创建一个表。创建表的查询如下 -mysql> create table bitDemo -> ( -...
    99+
    2023-10-22
  • python保留两位小数输出的方法是什么
    在Python中,保留两位小数输出可以使用以下两种方法:方法一:使用字符串格式化```num = 3.14159print("保留两...
    99+
    2023-10-10
    python
  • c++输出保留两位小数的方法是什么
    要在C++中输出保留两位小数,可以使用iomanip头文件中的setprecision函数。下面是一个简单的示例: #include...
    99+
    2024-03-02
    c++
  • javascript用函数式编程的原因是什么
    这篇“javascript用函数式编程的原因是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看...
    99+
    2024-04-02
  • 无数企业会选择微信小程序的原因是什么
    小编给大家分享一下无数企业会选择微信小程序的原因是什么,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!自从腾讯推出新形态的应用模式小程序主要就是想体现“用完即走”的...
    99+
    2023-06-27
  • 在javascript中使用alert函数出现中文会乱码的原因是什么
    在javascript中使用alert函数出现中文会乱码的原因是什么?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。可能原因一:javascript如果是写在一个...
    99+
    2023-06-14
  • vlookup函数匹配不出来的原因是什么
    今天小编给大家分享一下vlookup函数匹配不出来的原因是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。vlookup函...
    99+
    2023-06-30
  • php读取数据库出现中文乱码的原因是什么
    这篇文章主要介绍“php读取数据库出现中文乱码的原因是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“php读取数据库出现中文乱码的原因是什么”文章能帮助大家解决问题。一、数据库编码设置不正确在M...
    99+
    2023-07-05
  • js数字格式化为小数点后两位的方法是什么
    将数字格式化为小数点后两位的方法有多种,以下是其中两种常用的方法:1. 使用toFixed()方法:var num = 123.45...
    99+
    2023-05-13
    js数字格式化 js
  • 10个导致网站收录数量减少的原因分别是什么
    10个导致网站收录数量减少的原因分别是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。百度,一直都在完善自...
    99+
    2024-04-02
  • sql向上取整保留小数位的方法是什么
    在SQL中,可以使用内置函数CEILING来实现向上取整并保留小数位。CEILING函数返回大于或等于给定数字的最小整数,可以指定小...
    99+
    2023-09-15
    sql
  • 高防服务器租用后出现数据丢包的原因是什么
    高防服务器租用后出现数据丢包的原因:1.中转互联网时的传输网络问题。2.遇到大规模ddos攻击时导致的主机房网络问题。3.客户个人的网络问题。具体内容如下:一、转互联网的关键是浏览网络,从服务器,本地路由器一路跳出来,到主机房的核心交换机。...
    99+
    2024-04-02
  • php四舍五入保留两位小数的方法是什么
    可以使用PHP内置函数round()来进行四舍五入保留两位小数。例如:$number = 3.1415926;$rounded = ...
    99+
    2023-06-06
    php四舍五入 php
  • oracle四舍五入保留两位小数的方法是什么
    在Oracle中,可以使用ROUND函数来实现四舍五入并保留两位小数的功能。使用方法如下:```ROUND(number, 2)``...
    99+
    2023-09-04
    oracle
  • sql四舍五入保留两位小数的方法是什么
    在SQL中,可以使用函数来保留小数位数,常用的函数有ROUND、TRUNCATE和FORMAT等。以下是使用ROUND函数保留两位小...
    99+
    2023-05-14
    sql四舍五入 sql
  • 高防服务器租用后出现数据丢包的原因是什么呢
    高防服务器租用后出现数据丢包的原因:1.服务器跳出本地路由,一直到机房核心交换机造成中转网络故障。2.当机房遇到大流量攻击时造成服务器网络故障。3.用户本地的网络带宽信号不好或者发生了网络故障也会造成无法访问服务器。具体内容如下:一、中转网...
    99+
    2024-04-02
  • JVM中Xms和Xmx参数要设置为相同值的原因是什么
    这篇文章主要介绍了JVM中Xms和Xmx参数要设置为相同值的原因是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇JVM中Xms和Xmx参数要设置为相同值的原因是什么文章都会有所收获,下面我们一起来看看吧。I...
    99+
    2023-06-27
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作