zoukankan      html  css  js  c++  java
  • 将数值格式化成金额形式

    /** 
                 * 将数值格式化成金额形式 
                 * 
                 * @param num 数值(Number或者String) 
                 * @param precision 精度,默认不变
                 * @param separator 分隔符,默认为逗号
                 * @return 金额格式的字符串,如'1,234,567',默认返回NaN
                 * @type String 
                 */
                function formatNumber(num, precision, separator) {
                    var parts;
                    // 判断是否为数字
                    if (!isNaN(parseFloat(num)) && isFinite(num)) {
                        // 把类似 .5, 5. 之类的数据转化成0.5, 5, 为数据精度处理做准, 至于为什么
                        // 不在判断中直接写 if (!isNaN(num = parseFloat(num)) && isFinite(num))
                        // 是因为parseFloat有一个奇怪的精度问题, 比如 parseFloat(12312312.1234567119)
                        // 的值变成了 12312312.123456713
                        num = Number(num);
                        // 处理小数点位数
                        num = (typeof precision !== 'undefined' ? (Math.round(num * Math.pow(10, precision)) / Math.pow(10, precision)).toFixed(precision) : num).toString();
                        // 分离数字的小数部分和整数部分
                        parts = num.split('.');
                        // 整数部分加[separator]分隔, 借用一个著名的正则表达式
                        parts[0] = parts[0].toString().replace(/(d)(?=(d{3})+(?!d))/g, '$1' + (separator || ','));
    
                        return parts.join('.');
                    }
                    return NaN;
                }
    
                function getParams(name) {
                    var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)");
                    var r = window.location.search.substr(1).match(reg);
                    if (r != null) return unescape(r[2]); return null;
                }
    使用:formatNumber(calAmount,2,",")
  • 相关阅读:
    zabbix 主被动模式
    MySQL角色(role)功能介绍
    MySQL权限管理实战
    创建索引,这些知识应该了解
    MySQL锁等待与死锁问题分析
    Navicat操作MySQL简易教程
    职场里,对数据库要有敬畏之心!
    MySQL字段默认值设置详解
    MySQL查看及杀掉链接方法大全
    MySQL字段类型最全解析
  • 原文地址:https://www.cnblogs.com/ivan5277/p/12762336.html
Copyright © 2011-2022 走看看