您当前的位置:首页 > 计算机 > 编程开发 > Html+Div+Css(前端)

如何处理让人头疼的前端数字精准度问题

时间:12-14来源:作者:点击数:

前端的数字存在浮点数问题(受计算机处理精度的影响),如何去很好的解决这个难题呢?一般会采用升幂再降幂的方法。下面是重写的加减乘除方法:

// 以下是处理javascript小数精度加减乘除的四个的函数
/**
 * 必需要传的前两个参数:传入两个要计算的数字
 * 非必要传的最后一个参数:自己想要精确的位数
 */
const globalConst = {
  MAX_PRECISION: 8
}

// 计算两位数应该乘以的数,为加减乘数服务的函数
function formatNumber(num1, num2) {
  let r1, r2
  try {
    r1 = num1.toString().split('.')[1].length
  } catch (e) {
    r1 = 0
  }
  try {
    r2 = num2.toString().split('.')[1].length
  } catch (e) {
    r2 = 0
  }
  let sum = r1 + r2
  let sub = r2 - r1
  return { 'max': Math.pow(10, Math.max(r1, r2)), 'sum': Math.pow(10, sum), 'sub': Math.pow(10, sub) }
}

// 加法
const plus = function (num1, num2, n) {
  let formatNum = formatNumber(num1, num2).max
  let result = (num1 * formatNum + num2 * formatNum) / formatNum
  if (n) {
    return Number(result.toFixed(n))
  }
  return Number(result.toFixed(globalConst.MAX_PRECISION))
}

// 减法
const subtract = function (num1, num2, n) {
  let formatNum = formatNumber(num1, num2).max
  let result = (num1 * formatNum - num2 * formatNum) / formatNum
  if (n) {
    return Number(result.toFixed(n))
  }
  return Number(result.toFixed(globalConst.MAX_PRECISION))
}

// 乘法
const multiply = function (num1, num2, n) {
  let sum = formatNumber(num1, num2).sum
  let s1 = Number(num1.toString().replace('.', ''))
  let s2 = Number(num2.toString().replace('.', ''))
  let result = (s1 * s2) / sum
  if (n) {
    return Number(result.toFixed(n))
  }
  return Number(result.toFixed(globalConst.MAX_PRECISION))
}

// 除法
const divide = function (num1, num2, n) {
  let sub = formatNumber(num1, num2).sub
  let r1 = Number(num1.toString().replace('.', ''))
  let r2 = Number(num2.toString().replace('.', ''))
  let result = (r1 / r2) * sub
  if (n) {
    return Number(result.toFixed(n))
  }
  return Number(result.toFixed(globalConst.MAX_PRECISION))
}
方便获取更多学习、工作、生活信息请关注本站微信公众号城东书院 微信服务号城东书院 微信订阅号
推荐内容
相关内容
栏目更新
栏目热门
本栏推荐