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 相关文章推荐
JScript中的&quot;this&quot;关键字使用方式补充材料
Mar 08 Javascript
js查找父节点的简单方法
Jun 28 Javascript
自制轻量级仿jQuery.boxy对话框插件代码
Oct 26 Javascript
js中字符替换函数String.replace()使用技巧
Aug 14 Javascript
jQuery aminate方法定位到页面具体位置
Dec 26 Javascript
JS实现一个按钮的方法
Feb 05 Javascript
JQuery zClip插件实现复制页面内容到剪贴板
Nov 02 Javascript
详解js跨域原理以及2种解决方案
Dec 09 Javascript
老生常谈jquery id选择器和class选择器的区别
Feb 12 Javascript
详解AngularJS 模块化
Jun 14 Javascript
Vue触发式全局组件构建的方法
Nov 28 Javascript
es6数据变更同步到视图层的方法
Mar 04 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 SEO优化之URL优化方法
2011/04/21 PHP
三个类概括PHP的五种设计模式
2012/09/05 PHP
PHP实现的链式队列结构示例
2017/09/15 PHP
PHP PDOStatement::fetchObject讲解
2019/02/01 PHP
dojo 之基础篇(二)之从服务器读取数据
2007/03/24 Javascript
XML+XSL 与 HTML 两种方案的结合
2007/04/22 Javascript
关于onScroll事件在IE6下每次滚动触发三次bug说明
2011/09/21 Javascript
JavaScript实现GriwView单列全选(自写代码)
2013/05/13 Javascript
IE下JS读取xml文件示例代码
2013/08/05 Javascript
简单的Jquery全选功能
2013/11/07 Javascript
jquery实现点击弹出层效果的简单实例
2014/03/03 Javascript
jQuery选择器源码解读(四):tokenize方法的Expr.preFilter
2015/03/31 Javascript
jQuery插件ajaxFileUpload使用详解
2017/01/10 Javascript
Vue 2.0的数据依赖实现原理代码简析
2017/07/10 Javascript
JS实现闭包中的沙箱模式示例
2017/09/07 Javascript
Vue工程模板文件 webpack打包配置方法
2017/12/26 Javascript
vue项目,代码提交至码云,iconfont的用法说明
2020/07/30 Javascript
vue 使用rules对表单字段进行校验的步骤
2020/12/25 Vue.js
[40:12]Liquid vs Chaos 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/16 DOTA
编写Python脚本抓取网络小说来制作自己的阅读器
2015/08/20 Python
python制作花瓣网美女图片爬虫
2015/10/28 Python
Python中字符串的处理技巧分享
2016/09/17 Python
Python判断两个对象相等的原理
2017/12/12 Python
python实现彩票系统
2020/06/28 Python
pymongo中聚合查询的使用方法
2019/03/22 Python
python 中pyqt5 树节点点击实现多窗口切换问题
2019/07/04 Python
Django实现跨域请求过程详解
2019/07/25 Python
python 通过文件夹导入包的操作
2020/06/01 Python
巴黎欧莱雅法国官网:L’Oreal Paris
2019/04/30 全球购物
医学专业职业生涯规划范文
2014/02/05 职场文书
公司采购主管岗位职责
2014/06/17 职场文书
创新社会管理心得体会
2014/09/12 职场文书
五年级上册复习计划
2015/01/19 职场文书
英文慰问信
2015/02/14 职场文书
MYSQL如何查看进程和kill进程
2022/03/13 MySQL
Go语言grpc和protobuf
2022/04/13 Golang