js处理浮点数精度丢失问题

以下是个人封装的js方法,包括:
乘、除、加、减、保留小数数位
废话不多说,上代码~~~~~

// 自己实现
const toFixedSelf = (num, n) => {
  if (num < 0) {
    num = -num;
    return (parseInt(num * Math.pow(10, n) + 0.5, 10) / Math.pow(10, n)) * -1;
  } else {
    return parseInt(num * Math.pow(10, n) + 0.5, 10) / Math.pow(10, n);
  }
};
// 两个浮点数求和
const Add = (num1, num2) => {
  let r1;
  let r2;
  try {
    r1 = `${num1}`.split('.')[1].length;
  } catch (e) {
    r1 = 0;
  }
  try {
    r2 = `${num2}`.split('.')[1].length;
  } catch (e) {
    r2 = 0;
  }
  const m = Math.pow(10, Math.max(r1, r2));
  return Math.round(num1 * m + num2 * m) / m;
};
// 两个浮点数相减
const Sub = (num1, num2) => {
  let r1;
  let r2;
  try {
    r1 = `${num1}`.split('.')[1].length;
  } catch (e) {
    r1 = 0;
  }
  try {
    r2 = `${num2}`.split('.')[1].length;
  } catch (e) {
    r2 = 0;
  }
  const m = Math.pow(10, Math.max(r1, r2));
  const n = r1 >= r2 ? r1 : r2;
  return toFixedSelf(Math.round(num1 * m - num2 * m) / m, n);
};
// 两个浮点数相乘
const Mul = (num1, num2) => {
  let m = 0;
  const s1 = `${num1}`;
  const s2 = `${num2}`;
  try {
    m += s1.split('.')[1].length;
  } catch (e) {
    m = 0;
  }
  try {
    m += s2.split('.')[1].length;
  } catch (e) {
    m = m;
  }
  return (
    (Number(s1.replace('.', '')) * Number(s2.replace('.', ''))) /
    Math.pow(10, m)
  );
};
// 两个浮点数相除
const Div = (num1, num2) => {
  let t1;
  let t2;
  try {
    t1 = `${num1}`.split('.')[1].length;
  } catch (e) {
    t1 = 0;
  }
  try {
    t2 = `${num2}`.toString().split('.')[1].length;
  } catch (e) {
    t2 = 0;
  }
  const r1 = Number(`${num1}`.replace('.', ''));
  const r2 = Number(`${num2}`.toString().replace('.', ''));
  return (r1 / r2) * Math.pow(10, t2 - t1);
};
export default {
  toFixedSelf,
  Add,
  Sub,
  Mul,
  Div
};

记录一哈。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值