分享5个javascript的数字格式化函数

转载 2012年03月22日 16:30:33

来源:GBin1.com

Javascript没有任何内建的格式化函数,这里我们通过Google收集了5个javascript的数字格式化函数,希望对于大家的web开发能够带来方便。
十进制四舍五入
这两段代码帮助你做到四舍五入,对于你显示价格或者订单比较有用:
代码1:

unction CurrencyFormatted(amount) {
    var i = parseFloat(amount);
    if(isNaN(i)) { i = 0.00; }
    var minus = '';
    if(i < 0) { minus = '-'; }
    i = Math.abs(i);
    i = parseInt((i + .005) * 100);
    i = i / 100;
    s = new String(i);
    if(s.indexOf('.') < 0) { s += '.00'; }
    if(s.indexOf('.') == (s.length - 2)) { s += '0'; }
    s = minus + s;
    return s;
}
 
/**
*   Usage:  CurrencyFormatted(12345.678);
*   result: 12345.68
**/

代码2:

function format_number(pnumber,decimals){
    if (isNaN(pnumber)) { return 0};
    if (pnumber=='') { return 0};
     
    var snum = new String(pnumber);
    var sec = snum.split('.');
    var whole = parseFloat(sec[0]);
    var result = '';
     
    if(sec.length > 1){
        var dec = new String(sec[1]);
        dec = String(parseFloat(sec[1])/Math.pow(10,(dec.length - decimals)));
        dec = String(whole + Math.round(parseFloat(dec))/Math.pow(10,decimals));
        var dot = dec.indexOf('.');
        if(dot == -1){
            dec += '.';
            dot = dec.indexOf('.');
        }
        while(dec.length <= dot + decimals) { dec += '0'; }
        result = dec;
    } else{
        var dot;
        var dec = new String(whole);
        dec += '.';
        dot = dec.indexOf('.');    
        while(dec.length <= dot + decimals) { dec += '0'; }
        result = dec;
    }  
    return result;
}
 
/**
*   Usage:  format_number(12345.678, 2);
*   result: 12345.68
**/
添加逗号
这俩段代码帮助你添加逗号到每三位数字中,这让大的数字比较容易查看。

代码1:

function CommaFormatted(amount) {
    var delimiter = ","; // replace comma if desired
    amount = new String(amount);
    var a = amount.split('.',2)
    var d = a[1];
    var i = parseInt(a[0]);
    if(isNaN(i)) { return ''; }
    var minus = '';
    if(i < 0) { minus = '-'; }
    i = Math.abs(i);
    var n = new String(i);
    var a = [];
    while(n.length > 3)
    {
        var nn = n.substr(n.length-3);
        a.unshift(nn);
        n = n.substr(0,n.length-3);
    }
    if(n.length > 0) { a.unshift(n); }
    n = a.join(delimiter);
    if(d.length < 1) { amount = n; }
    else { amount = n + '.' + d; }
    amount = minus + amount;
    return amount;
}
 
/**
*   Usage:  CommaFormatted(12345678);
*   result: 12,345,678
**/
数字格式化,来自PHP
这段javascript代码功能设计来自PHP的nubmer_format功能。能够四舍五入并且加入逗号分隔。而且可以自定义10进制分隔。

function number_format (number, decimals, dec_point, thousands_sep) {
 
    number = (number + '').replace(/[^0-9+-Ee.]/g, '');
    var n = !isFinite(+number) ? 0 : +number,
        prec = !isFinite(+decimals) ? 0 : Math.abs(decimals),
        sep = (typeof thousands_sep === 'undefined') ? ',' : thousands_sep,
        dec = (typeof dec_point === 'undefined') ? '.' : dec_point,
        s = '',
        toFixedFix = function (n, prec) {
            var k = Math.pow(10, prec);
            return '' + Math.round(n * k) / k;
        };
    // Fix for IE parseFloat(0.55).toFixed(0) = 0;
    s = (prec ? toFixedFix(n, prec) : '' + Math.round(n)).split('.');
    if (s[0].length > 3) {
        s[0] = s[0].replace(/B(?=(?:d{3})+(?!d))/g, sep);
    }
    if ((s[1] || '').length < prec) {
        s[1] = s[1] || '';
        s[1] += new Array(prec - s[1].length + 1).join('0');
    }
    return s.join(dec);
}
 
/**
*   Usage:  number_format(123456.789, 2, '.', ',');
*   result: 123,456.79
**/

添加一个英文的排序后缀 

Number.prototype.toOrdinal = function() {
    var n = this % 100;
    var suffix = ['th', 'st', 'nd', 'rd', 'th'];
    var ord = n < 21 ? (n < 4 ? suffix[n] : suffix[0]) : (n % 10 > 4 ? suffix[0] : suffix[n % 10]);
    return this + ord;
}
 
/*
*   Usage:
*   var myNumOld = 23
*   var myNumNew = myNumOld.toOrdinal()
*   Result: 23rd
*/

除去非数字的字符

function stripNonNumeric( str )
{
  str += '';
  var rgx = /^d|.|-$/;
  var out = '';
  for( var i = 0; i < str.length; i++ )
  {
    if( rgx.test( str.charAt(i) ) ){
      if( !( ( str.charAt(i) == '.' && out.indexOf( '.' ) != -1 ) ||
             ( str.charAt(i) == '-' && out.length != 0 ) ) ){
        out += str.charAt(i);
      }
    }
  }
  return out;
}
 
/*
*   Usage: stripNonNumeric('123et45dhs6.789');
*   Result: 123456.789
*/ 



5个javascript的数字格式化函数

Javascript没有任何内建的格式化函数,这里我们通过Google收集了5个javascript的数字格式化函数,希望对于大家的web开发能够带来方便。 十进制四舍五入 这两段代码帮助你做...
  • whqwyn
  • whqwyn
  • 2017年02月13日 16:28
  • 104

JavaScript 数字格式化函数

以下是4个有用的JS数字格式化函数   1. 四舍五入  下面两个函数都能对浮点数进行四舍五入,保留小数点后两位。  2. 给数字添加逗号  每三位数字添加一个逗号,方便阅读  3....
  • liuzp111
  • liuzp111
  • 2015年06月12日 09:53
  • 375

JS实现数字千位符格式化方法

/** * * @param num * @param precision * @param separator * @returns {*} *=====================...
  • a3025056
  • a3025056
  • 2017年01月19日 15:06
  • 208

Java数字格式化、Math类、随机数笔记

数字格式化DecimalFormat是NumberFormat的一个子类,用于格式化十进制数字。将一些数字格式化为整数、浮点数、科学计数法,百分数等。可以为要输出的数字加上单位或控制数字的精度。 可...
  • u014084081
  • u014084081
  • 2015年03月03日 15:43
  • 689

Android 系列 6.27格式化数字

6.27格式化数字 问题 您需要格式化数字,因为Double.toString()和朋友的默认格式不能给您足够的控制结果的显示方式。 解 使用String.format()或NumberFormat子...
  • sergeycao
  • sergeycao
  • 2017年01月14日 11:25
  • 562

`JavaScript`格式化货币数字

`JavaScript`格式化货币数字
  • DeepLies
  • DeepLies
  • 2017年06月13日 13:34
  • 489

javascript 格式化数字

/** * 数字格式化 * @param src 源数据 * @param fengewei 多少位一分割 * @param baoliuweishu 保留小数位数 * @param dia...
  • yuliqi0429
  • yuliqi0429
  • 2016年04月08日 15:06
  • 242

Java NumberFormat数字、货币值和百分数等的格式化处理

Java数字、货币值和百分数等的格式化处理 博客分类: JAVA JAVA数字格式化DecimalFormat  如果我们用下列语句输出一个数 System.out.println(1234...
  • qq_26869449
  • qq_26869449
  • 2016年06月06日 09:31
  • 13558

javascript格式化数字输入

1.在客户输入数量的时候,能够将客户输入的数量三位三位的分开显示,具体如“123,456,234”等等。         function getArray(obj) {             va...
  • aabbjj
  • aabbjj
  • 2013年09月05日 13:44
  • 556

jsp页面格式化数字或时间

转载自:http://blog.csdn.net/hakunamatata2008/archive/2011/01/21/6156203.aspx  所有标签:  Tags    fmt:r...
  • xyw591238
  • xyw591238
  • 2016年11月23日 10:50
  • 1193
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:分享5个javascript的数字格式化函数
举报原因:
原因补充:

(最多只允许输入30个字)