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 相关文章推荐
javascript 新浪背投广告实现代码
Jul 07 Javascript
点击文章内容处弹出页面代码
Oct 01 Javascript
通过一段代码简单说js中的this的使用
Jul 23 Javascript
jQuery插件jRumble实现网页元素抖动
Jun 05 Javascript
JavaScript实现iframe自动高度调整和不同主域名跨域
Feb 27 Javascript
JavaScript与JQUERY获取元素的宽、高和位置
Feb 26 Javascript
jQuery插件Echarts实现的双轴图效果示例【附demo源码下载】
Mar 04 Javascript
基于vue实现swipe分页组件实例
May 25 Javascript
jQuery中的$是什么意思及 $. 和 $().的区别
Apr 20 jQuery
vuex进阶知识点巩固
May 20 Javascript
Vue使用mixin分发组件的可复用功能
Sep 01 Javascript
Vue动态加载图片在跨域时无法显示的问题及解决方法
Mar 10 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日期时间如何转换(UNIX时间戳和格式化日期)
2012/07/15 PHP
Yii中CGridView实现批量删除的方法
2015/12/28 PHP
Javascript中的for in循环和hasOwnProperty结合使用
2013/06/05 Javascript
js禁止页面刷新禁止用F5键刷新禁止右键的示例代码
2013/09/23 Javascript
一个简单的动态加载js和css的jquery代码
2014/09/01 Javascript
JavaScript使用shift方法移除素组第一个元素实例分析
2015/04/06 Javascript
浅析JS异步加载进度条
2016/05/05 Javascript
易被忽视的js事件问题总结
2016/05/14 Javascript
JS获取和修改元素样式的实例代码
2016/08/06 Javascript
详解jQuery中的DOM操作
2016/12/23 Javascript
Angular4如何自定义首屏的加载动画详解
2017/07/26 Javascript
javascript实现文字无缝滚动效果
2017/08/26 Javascript
vscode下vue项目中eslint的使用方法
2019/01/13 Javascript
JSON是什么?有哪些优点?JSON和XML的区别?
2019/04/29 Javascript
JavaScript静态作用域和动态作用域实例详解
2019/06/17 Javascript
js实现图片跟随鼠标移动效果
2019/10/16 Javascript
nodejs开发一个最简单的web服务器实例讲解
2020/01/02 NodeJs
Js实现复选框的全选、全不选反选功能代码实例
2020/02/28 Javascript
JavaScript前端实现压缩图片功能
2020/03/06 Javascript
JQuery事件冒泡和默认行为代码实例
2020/05/13 jQuery
Javascript实现关闭广告效果
2021/01/29 Javascript
[02:45]2016年中国刀塔全程回顾,完美“圣”典即将上演
2016/12/15 DOTA
在Django的视图中使用form对象的方法
2015/07/18 Python
详解MySQL数据类型int(M)中M的含义
2016/11/20 Python
python3库numpy数组属性的查看方法
2018/04/17 Python
python 判断网络连通的实现方法
2018/04/22 Python
Atom的python插件和常用插件说明
2018/07/08 Python
Django ManyToManyField 跨越中间表查询的方法
2018/12/18 Python
python 实现UTC时间加减的方法
2018/12/31 Python
区分python中的进程与线程
2020/08/13 Python
小学英语教学反思案例
2014/02/04 职场文书
绿色环保口号
2014/06/12 职场文书
2015元旦家电促销活动策划方案
2014/12/09 职场文书
云冈石窟导游词
2015/02/04 职场文书
2015年敬老院工作总结
2015/05/18 职场文书
三严三实学习心得体会(精选N篇)
2016/01/05 职场文书