产品经理:优惠金额只舍不入,支付金额只入不舍...

前言

当前做的项目是一个售卖会员的平台。其中涉及到优惠券、支付金额等。

优惠券分为:折扣券(n折)、抵扣券(减x元)

需求

优惠金额、支付金额都需要保留两位小数。
优惠金额 只舍不入,比如18.811元,显示为:18.82元。这样看起来,优惠的相对多一些
支付金额 只入不舍,比如18.888元,显示为:18.88元。

从产品角度来讲,这个设计相当人性化。

实现

js 复制代码
/**
 * 金额计算
 * @param {number} a sku原始价格
 * @param {number} b 优惠券金额/折扣
 * @param {string} mathFunc  四舍五入:round/ceil/floor 
 * @param {string} type  计算方式默认减法
 * @param {digits} type  精度,默认两位小数
 * */
export function numbleCalc(a, b,mathFunc='round', type = '-',digits=2) {

    var getDecimalLen = num =>{
        return num.toString().split('.')[1] ? num.toString().split('.')[1].length : 0;
    }

    var c;
    //获取2个数字中,最长的小数位数
    var aLen = getDecimalLen(a);
    var bLen = getDecimalLen(b);
    var decimalLen = aLen>bLen?aLen:bLen;
    var mul = decimalLen>0?(10 ** decimalLen):1;
    

    if(type=='-'){
         c = (a * mul - b*mul)/mul;
    }else if(type=='*'){
         c = (a*mul) * (b*mul)/mul/mul;
    }

    c  = digits==0?c : c * (10 ** digits);

    if(mathFunc=='floor'){
        c= Math.floor(c);
    }else if(mathFunc=='ceil'){
        c= Math.ceil(c);
    }else {
        c= Math.round(c);
    }
    return digits==0?c : c/(10**digits);
}

整体思路:获取两个数字之间最大的小数位,先取整再计算。 不直接进行计算,是因为存在0.1+0.2!=0.3的情况,具体原因可以看下文章下方的参考链接,写的很详细。

  • Math.ceil() 总是向上舍入,并返回大于等于给定数字的最小整数。
  • Math.floor() 函数总是返回小于等于一个给定数字的最大整数。
  • Math.round() 四舍五入

总结

封装的这个函数,只考虑了当前业务场景,未兼容一些边界值情况。

  • 大金额计算问题
  • 计算方式:加法、除法未做处理

参考

# 前端金额运算精度丢失问题及解决方案

相关推荐
西洼工作室几秒前
python邮箱令牌/点击验证、邮箱验证码实现
前端·python
iCxhust28 分钟前
在 emu8086 中可以直接编译运行的完整汇编程序,演示数组的定义、遍历、求和、求最大值。
开发语言·前端·javascript·汇编·单片机·嵌入式硬件·算法
JianZhen✓32 分钟前
2026前端高频面试题总结(Vue/JS/网络/Webpack/性能优化/手写)
前端·javascript·vue.js
里欧跑得慢36 分钟前
Flutter 主题管理:构建一致的用户界面
前端·css·flutter·web
龙猫里的小梅啊1 小时前
CSS(八)CSS显示模式display属性
前端·css·css3
雨季mo浅忆1 小时前
第二项目重新梳理
前端·面试
李白的天不白1 小时前
webpack 与 vue-loader 版本冲突问题
前端·vue.js·webpack
sunneo1 小时前
专栏D-团队与组织-05-冲突与决策
前端·人工智能·产品运营·aigc·产品经理·ai-native
舟遥遥娓飘飘1 小时前
量化投资体系之二:为 Web 看板集成公众号/财经原始数据
前端·数据分析·自动化·ai编程