Vue 数字相加、相减精度丢失处理。

Vue 数字相加、相减精度丢失处理。

方法 一:

javascript">// num 是数值,decimals是精度几位
function round(num, decimals) {
  const factor = Math.pow(10, decimals);
  return Math.round(num * factor) / factor;
}

const a = 0.1;
const b = 0.2;

console.log(round(a + b, 1)); // 0.3

方法 二:

//可以传你要的小数几位
let num = 2
const a = 0.1;
const b = 0.2;
console.log((a+b).toFixed(num)); // 0.30

方法 三:扩大运算范围:将浮点数转化为整数,相乘或相加后再除回去,可以避免小数位精度的影响。

let num1 = 0.1;
let num2 = 0.2;
let sum = (num1 * 10 + num2 * 10) / 10;
console.log(sum); // 0.3

最后就是使用第三方库:例如 decimal.js、big.js 等第三方库可以提供更高精度的浮点数运算。

转载请说明出处内容投诉
CSS教程_站长资源网 » Vue 数字相加、相减精度丢失处理。

发表评论

欢迎 访客 发表评论

一个令你着迷的主题!

查看演示 官网购买