js处理价格数据,每三位加逗号,强制保留两位小数

需求说明:页面发送请求,需要显示商品的价格,后台从数据库中将价格取出,js处理价格数据,使用金额的标准格式将价格展示在前台。

如下图所示:


数据库存的数据如下:


前台得到的价格数据,如果小数为0的话会自动省略,这样就导致前台不能展示理想的价格数据。这里,笔者就按照财务对价格的标准写法在js中处理好价格数据然后再展示。

分析:目前主流的价格表示方法,第一,小数精确到分,即保留两位小数,如果价格数据是一个整数的话,就添加.00,即所有的价格都强制保留两位小数。第二,整数部分从右向左每隔三位添加一个逗号。这样显示的价格有模有样,一目了然,格式整齐。

定义一个有参的函数封装价格转换方法,传的参数即为需要转换的价格,需要转换价格时直接调用这个函数即可。

js函数代码如下:

//价格处理
function priceSwitch(x) {
    //强制保留两位小数
    var f = parseFloat(x);
    if (isNaN(f)) return false;
    var f = Math.round(x * 100) / 100;
    var s = f.toString();
    var rs = s.indexOf('.');
    if (rs < 0) {
        rs = s.length;
        s += '.';
    }
    while (s.length < (rs + 1) + 2) {
        s += '0';
    }
    //每三位用一个逗号隔开
    var leftNum=s.split(".")[0];
    var rightNum="."+s.split(".")[1];
    var result;
    //定义数组记录截取后的价格
    var resultArray=new Array();
    if(leftNum.length>3){
        var i=true;
        while (i){
            resultArray.push(leftNum.slice(-3));
            leftNum=leftNum.slice(0,leftNum.length-3);
            if(leftNum.length<4){
                i=false;
            }
        }
        //由于从后向前截取,所以从最后一个开始遍历并存到一个新的数组,顺序调换
        var sortArray=new Array();
        for(var i=resultArray.length-1;i>=0;i--){
            sortArray.push(resultArray[i]);
        }
        result=leftNum+","+sortArray.join(",")+rightNum;
    }else {
        result=s;
    }
    return result;
}

示例:




该函数最关键之处就是字符串截取和新的字符串重新排列组合。






评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值