原生toFixed的bug

存在的问题 - 有些浏览器会存在这个问题

bash 复制代码
(1.35).toFixed(1) // '1.4'
(1.45).toFixed(1) // '1.4'
(1.55).toFixed(1) // '1.6'

1.45应该返回的是1.5

解决方案:

bash 复制代码
Number.prototype.toFixed = function(decimal){
  let str = this.toString()
  let strArr = str.split('.')
  let d = parseInt(decimal)
  // 参数为 0 和 非数字
  if(!d){
    return strArr[0]
  }
  // 整数
  if(str.indexOf('.') == -1){
    return str + '.' + '0'.repeat(d)
  }
  // 小数位不够
  if(strArr[1].length <= d){
    return str + '0'.repeat(d - strArr[1].length)
  }
  let num = strArr[1].charAt(d)
  strArr[1] = strArr[1].slice(0, d)
  // 有进位
  if(num - 5 >=0){
    let bit = this < 0 ? -1 : 1
    // 进位,正数加 1,负数加 -1
    let n = Number(strArr.join('')) + bit
    // 进位之后保留对应小数位
    let reg = new RegExp('(\\d{'+ d +'})$')
    return n.toString().replace(reg, '.$1')
  }
  return strArr.join('.')
}

原因:并非单纯的四舍五入,而是四舍六入五取偶的方法

​四舍​:当被修约的数字小于5时,该数字舍去。

​六入​:当被修约的数字大于等于6时,该数字舍去并向前进一位。

​五凑偶​:当被修约的数字为5时,处理较为复杂:

如果5后还有不为"0"的任何数,无论5的前面是奇数还是偶数,均应进位。

如果5后无有效数字,则需看5前面的数字。若为奇数,则向前进一位;若为偶数(包括0),则直接舍去5不进位。

相关推荐
xiaoqi92240 分钟前
React Native鸿蒙跨平台如何实现分类页面组件通过searchQuery状态变量管理搜索输入,实现了分类的实时过滤功能
javascript·react native·react.js·ecmascript·harmonyos
打小就很皮...1 小时前
Tesseract.js OCR 中文识别
前端·react.js·ocr
qq_177767371 小时前
React Native鸿蒙跨平台实现应用介绍页,实现了应用信息卡片展示、特色功能网格布局、权限/联系信息陈列、评分展示、模态框详情交互等通用场景
javascript·react native·react.js·ecmascript·交互·harmonyos
2603_949462101 小时前
Flutter for OpenHarmony社团管理App实战:预算管理实现
android·javascript·flutter
wuhen_n1 小时前
JavaScript内存管理与执行上下文
前端·javascript
Hi_kenyon2 小时前
理解vue中的ref
前端·javascript·vue.js
jin1233222 小时前
基于React Native鸿蒙跨平台地址管理是许多电商、外卖、物流等应用的重要功能模块,实现了地址的添加、编辑、删除和设置默认等功能
javascript·react native·react.js·ecmascript·harmonyos
2501_920931703 小时前
React Native鸿蒙跨平台医疗健康类的血压记录,包括收缩压、舒张压、心率、日期、时间、备注和状态
javascript·react native·react.js·ecmascript·harmonyos
落霞的思绪3 小时前
配置React和React-dom为CDN引入
前端·react.js·前端框架
Hacker_Z&Q3 小时前
CSS 笔记2 (属性)
前端·css·笔记