vue JS小数相加 相乘

vue JS小数相加 相乘

项目中使用到金额以及数量的计算, 出现了 js 精度失去精度的问题

// methods 方法
methods: {
	// 获取总金额
    changeIpt(e, row) {
      let that = this;
      that.form.totalAmount = 0;
      that.form.totalNumber = 0;
      row.amount = this.accMul(row.number, row.unitPrice);
      console.log(this.inWarehouseDetailList, "获取数据");
      for (let i = 0; i < this.inWarehouseDetailList.length; i++) {
      // 方法调用 传入 (金额, 数量) 
        var money = this.accMul(
          this.inWarehouseDetailList[i].number,
          this.inWarehouseDetailList[i].unitPrice
        );
        that.form.totalAmount += money;

        that.form.totalNumber += Number(this.inWarehouseDetailList[i].number);

        this.$forceUpdate();
      }
    },
	// 数字相乘
	accMul(arg1, arg2) {
      var m = 0,
        s1 = arg1.toString(),
        s2 = arg2.toString();
      try {
        m += s1.split(".")[1].length;
      } catch (e) {}
      try {
        m += s2.split(".")[1].length;
      } catch (e) {}
      return (
        (Number(s1.replace(".", "")) * Number(s2.replace(".", ""))) /
        Math.pow(10, m)
      );
    },
	// 金额相加
	addMul(arg1, arg2) {
	      var m = 0,
	        s1 = arg1.toString(),
	        s2 = arg2.toString();
	      try {
	        m += s1.split(".")[1].length;
	      } catch (e) {}
	      try {
	        m += s2.split(".")[1].length;
	      } catch (e) {}
	      return (
	        Number(s1.replace(".", "")) +
	        Number(s2.replace(".", "")) / Math.pow(10, m)
	      );
	    },
}



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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值