Javascript中 toFixed四舍六入方法


Posted in Javascript onAugust 21, 2017

javascript中toFixed使用的是银行家舍入规则。

银行家舍入:所谓银行家舍入法,其实质是一种四舍六入五取偶(又称四舍六入五留双)法。

简单来说就是:四舍六入五考虑,五后非零就进一,五后为零看奇偶,五前为偶应舍去,五前为奇要进一。但是不论引入toFixed解决浮点数计算精度缺失的问题也好,它有没有使用银行家舍入法也罢,都是为了解决精度的问题,但是又离不开二进制浮点数的环境,但至少他帮助我们找到了问题所在,从而让我们有解决方法。

Number.prototype.toFixed = function(length)
    {
      var carry = 0; //存放进位标志
      var num,multiple; //num为原浮点数放大multiple倍后的数,multiple为10的length次方
      var str = this + ''; //将调用该方法的数字转为字符串
      var dot = str.indexOf("."); //找到小数点的位置
      if(str.substr(dot+length+1,1)>=5) carry=1; //找到要进行舍入的数的位置,手动判断是否大于等于5,满足条件进位标志置为1
      multiple = Math.pow(10,length); //设置浮点数要扩大的倍数
      num = Math.floor(this * multiple) + carry; //去掉舍入位后的所有数,然后加上我们的手动进位数
      var result = num/multiple + ''; //将进位后的整数再缩小为原浮点数
      /*
      * 处理进位后无小数
      */
      dot = result.indexOf(".");
      if(dot < 0){
        result += '.';
        dot = result.indexOf(".");
      }
      /*
      * 处理多次进位
      */
      var len = result.length - (dot+1);
      if(len < length){
        for(var i = 0; i < length - len; i++){
          result += 0;
        }
      }
      return result;
    }

该方法的大致思路是首先找到舍入位,判断该位置是否大于等于5,条件成立手动进一位,然后通过参数大小将原浮点数放大10的参数指数倍,然后再将包括舍入位后的位数利用floor全部去掉,根据我们之前的手动进位来确定是否进位。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
用tip解决Ext列宽度不够的问题
Dec 13 Javascript
JavaScript和CSS通过expression实现Table居中显示
Jun 28 Javascript
Jquery.Form 异步提交表单的简单实例
Mar 03 Javascript
javascript实现checkbox全选的代码
Apr 30 Javascript
jquery.validate 自定义验证方法及validate相关参数
Jan 18 Javascript
新手vue构建单页面应用实例代码
Sep 18 Javascript
js定时器实现倒计时效果
Nov 05 Javascript
webpack v4 从dev到prd的方法
Apr 02 Javascript
Vue 实现树形视图数据功能
May 07 Javascript
layer.open关闭父窗口 以及调用父页面的方法
Aug 17 Javascript
小程序实现搜索框
Jun 19 Javascript
vue+animation实现翻页动画
Jun 29 Javascript
webpack使用 babel-loader 转换 ES6代码示例
Aug 21 #Javascript
JavaScript创建对象的七种方式全面总结
Aug 21 #Javascript
webpack处理 css\less\sass 样式的方法
Aug 21 #Javascript
Vue中建立全局引用或者全局命令的方法
Aug 21 #Javascript
JS实现身份证输入框的输入效果
Aug 21 #Javascript
Vue自定义指令使用方法详解
Aug 21 #Javascript
javascript实现Java中的Map对象功能的实例详解
Aug 21 #Javascript
You might like
详解PHP显示MySQL数据的三种方法
2008/06/05 PHP
MySQL时间字段究竟使用INT还是DateTime的说明
2012/02/27 PHP
php获取$_POST同名参数数组的实现介绍
2013/06/30 PHP
PHP的fsockopen、pfsockopen函数被主机商禁用的解决办法
2014/07/08 PHP
PHP将回调函数作用到给定数组单元的方法
2014/08/19 PHP
PHP简单获取网站百度搜索和搜狗搜索收录量的方法
2016/08/23 PHP
PHP 多任务秒级定时器的实现方法
2018/05/13 PHP
php实现的rc4加密解密类定义与用法示例
2018/08/16 PHP
window.onload追加函数使用示例
2014/03/03 Javascript
如何判断微信内置浏览器(通过User Agent实现)
2014/09/01 Javascript
jQuery实现可用于博客的动态滑动菜单完整实例
2015/09/17 Javascript
JavaScript阻止回车提交表单的方法
2015/12/30 Javascript
BootStrap的弹出框(Popover)支持鼠标移到弹出层上弹窗层不隐藏的原因及解决办法
2016/04/03 Javascript
Javascript之Math对象详解
2016/06/07 Javascript
BootStrap框架中的data-[ ]自定义属性理解(推荐)
2017/02/14 Javascript
Angular中实现树形结构视图实例代码
2017/05/05 Javascript
Node.js实现文件上传的示例
2017/06/28 Javascript
BootStrap 页签切换失效的解决方法
2017/08/17 Javascript
ubuntu编译nodejs所需的软件并安装
2017/09/12 NodeJs
vue 路由嵌套高亮问题的解决方法
2018/05/17 Javascript
在vue中实现清除echarts上次保留的数据(亲测有效)
2020/09/09 Javascript
js实现磁性吸附的示例
2020/10/26 Javascript
[00:39]DOTA2上海特级锦标赛 Liquid战队宣传片
2016/03/04 DOTA
Python数据类型详解(三)元祖:tuple
2016/05/08 Python
Python中实例化class的执行顺序示例详解
2018/10/14 Python
python遍历文件目录、批量处理同类文件
2019/08/31 Python
Python实现word2Vec model过程解析
2019/12/16 Python
Python3.5 win10环境下导入kera/tensorflow报错的解决方法
2019/12/19 Python
浅析关于Keras的安装(pycharm)和初步理解
2020/10/23 Python
国际旅客访问北美最大的汽车租赁提供商:Alamo Rent A Car
2018/06/13 全球购物
How TDD works
2012/09/30 面试题
党校自我鉴定范文
2013/10/02 职场文书
机关出纳岗位职责
2014/04/03 职场文书
乡文化站暑期培训方案
2014/08/28 职场文书
求职自荐信范文(优秀篇)
2015/03/27 职场文书
药房管理制度范本
2015/08/06 职场文书