• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧
您的位置:首页 > CMS教程 >建站教程 > 怎么解决javascript数字计算丢失精度问题?

怎么解决javascript数字计算丢失精度问题?

作者:站长图库 字体:[增加 减小] 来源:互联网 时间:2022-04-29

站长图库向大家介绍了javascript数字计算,丢失精度问题等相关知识,希望对您有所帮助

怎么解决javascript数字计算丢失精度问题?


js数字计算丢失精度问题解决方案

计算机世界里,数字的计算,所有语言都会丢失精度,所以没有万全之策,但在人力范围内,尽量解决。

网上找了一部分代码,发现是有问题的,比如:

//加法 Number.prototype.myAdd = function(arg2) {    var arg1 = this;    if (isNaN(arg2)) {        return 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.prototype.mySub = function(arg2) {    var arg1 = this;    if (isNaN(arg2)) {        return arg2;    }    var r1, r2, m, n;    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));    n = (r1 >= r2) ? r1 : r2;    return ((arg1 * m - arg2 * m) / m).toFixed(n);}//乘法 Number.prototype.myMul = function(arg2) {    var arg1 = this;    if (isNaN(arg2)) {        return 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.prototype.myDiv = function(arg2) {    var arg1 = this;    if (isNaN(arg2)) {        return 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).myMul(pow(10, t2 - t1))    }}

在计算一些特殊的数字时,仍然有问题:

比如加法:

268.34.myDiv(0.83);//321.7505995203837

所以还要优化

我重新做了一版:

var operationNumber = function (arg1,arg2,operator) {    var oper=['+','-','*','/'];    // 不合法的运算    if (isNaN(arg1)||isNaN(arg2)||oper.indexOf(operator)<0) {        return NaN;    }    // 除以0    if (operator==='/'&&Number(arg2)===0) {        return Infinity;    }    // 和0相乘    if (operator==='*'&&Number(arg2)===0) {        return 0;    }    // 相等两个数字相减    if ((arg1===arg2||Number(arg1)===Number(arg2))&&operator==='-') {        return 0;    }    var r1, r2, max,_r1,_r2;    try { r1 = arg1.toString().split(".")[1].length } catch (e) { r1 = 0 }    try { r2 = arg2.toString().split(".")[1].length } catch (e) { r2 = 0 }    max = Math.max(r1, r2)    _r1 = max-r1;    _r2 = max-r2;    if (_r1!==0) {        arg1=arg1+'0'.repeat(_r1)    }    if (_r2!==0) {        arg2=arg2+'0'.repeat(_r2)    }    arg1 = Number(arg1.toString().replace('.',''))    arg2 = Number(arg2.toString().replace('.',''))    var r3 = operator==='*'?(max*2):(operator==='/'?0:max);    var newNum = eval(arg1+operator+arg2);    if (r3!==0) {        var nStr = newNum.toString();        nStr = nStr.replace(/^-/,'');        if (nStr.length<r3+1) {            nStr = '0'.repeat(r3+1-nStr.length)+nStr;        }        nStr = nStr.replace(new RegExp('(\\\d{'+r3+'})$'),'.$1');        if (newNum<0) {            nStr = '-'+nStr;        }        newNum = nStr*1;    }    return newNum;}//加法 Number.prototype.myAdd = function(arg2) {    return operationNumber(this,arg2,'+');}//减法 Number.prototype.mySub = function(arg2) {    return operationNumber(this,arg2,'-');}//乘法 Number.prototype.myMul = function(arg2) {    return operationNumber(this,arg2,'*');}// 除法Number.prototype.myDiv = function(arg2) {    return operationNumber(this,arg2,'/');}

如果你发现了bug,评论区及时反馈,我及时跟进修复。


分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 怎么解决javascript数字计算丢失精度问题?

相关文章

  • 2022-04-29代码如何实现移除WordPress版本号
  • 2022-04-29illustrator制做透明气泡
  • 2022-04-29将DedeCMS根目录下的data目录迁移到web以外目录方法
  • 2022-04-29PS设计制作蓝色梦幻泡泡背景的详细教程
  • 2022-04-29Python查询工信部网站备案信息
  • 2022-04-29搜索引擎优化的文章营销策略
  • 2022-04-29苹果cms播放器无法全屏修复方法
  • 2022-04-29实例详解之怎样使用css实现3D穿梭效果
  • 2022-04-29详解thinkphp5.1/5.0定时任务的实现步骤
  • 2022-04-29Photoshop CS6制作3D文字的片头动画教程

文章分类

  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧

最近更新的内容

    • Alexa优化技巧大全
    • 手把手教你在node中怎么优雅打印全链路日志
    • Photoshop制作超酷的3D岩石字体教程
    • 五步搞定Laravel Migrations的使用
    • JavaScript中如何判断函数、变量是否存在
    • 【jquery】ajax 请求成功后新开窗口被拦截解决方法
    • wordpress的login.php打不开怎么办
    • Nodejs路由可通过什么模块实现的
    • 浅析node Express框架中的 res.send() 和 res.end()
    • 4种移动端适配方法

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有