超大数字四舍五入保留N位小数【没bug】

大部分npm常用的插件四舍五入都是用数值直接去计算四舍五入的存在精度问题,本方法是用用字符串拆分比较整数大小,这样就避开了精度的问题;

该方法可以传入:1.134、99.99、9999999999999999999.99999、.001、12.、0.、00.、类似的奇葩字符都会自动处理补全

代码如下:

javascript 复制代码
function setRound(v, n) {
  if(isNaN(v)) return 'NaN';
  const values = v.split(".");
  function get0(lastV){
    // 补0函数
    var s0 = lastV + '0000000000000000000000'
    return s0.substring(0, n)
  }
  let integerStr = values[0];
  let decimalStr2 = values[1].substring(0, n)
  let decimalStr = values[1].substring(0, n+1);
  const lastN = Number(decimalStr.slice(-1));
  if(!values[1]) return integerStr + "." + get0(decimalStr2);
  if(decimalStr && decimalStr.length > n){ // 小数位超过n位数
    if(lastN >= 5){
      decimalStr2 = decimalStr2 - 0 + 1 // 五入
      if(decimalStr2.toString().length > n){ // 如果小数位超过n+1位数
        decimalStr2 = get0('0')
        integerStr = Number(integerStr) + 1
      }
    }
  }
  integerStr = Number(integerStr) // 规范00.134、.134这种整数位
  return integerStr + "." + get0(decimalStr2)
}
相关推荐
前端 贾公子9 分钟前
vue移动端适配方案 === postcss-px-to-viewport
前端·javascript·html
GISer_Jing1 小时前
AI营销增长:4大核心能力+前端落地指南
前端·javascript·人工智能
m0_471199633 小时前
【场景】前端怎么解决离线收银、数据同步异常等场景问题
前端·javascript
栀秋6664 小时前
“无重复字符的最长子串”:从O(n²)哈希优化到滑动窗口封神,再到DP降维打击!
前端·javascript·算法
xhxxx4 小时前
不用 Set,只用两个布尔值:如何用标志位将矩阵置零的空间复杂度压到 O(1)
javascript·算法·面试
有意义4 小时前
斐波那契数列:从递归到优化的完整指南
javascript·算法·面试
Mr.Jessy4 小时前
JavaScript高级:深入对象与内置构造函数
开发语言·前端·javascript·ecmascript
温宇飞4 小时前
深入理解 JavaScript 模块系统:CJS 与 ESM 的实现原理
javascript
幸运小圣4 小时前
深入理解ref、reactive【Vue3工程级指南】
前端·javascript·vue.js