79

PHP 関数:

function formatNumberForDisplay($number, $decimal=0, $decimalSeperator='.', $numberSeperator=',')
{
     return number_format($number, $decimal, $decimalSeperator, $numberSeperator);
}

jQuery/JavaScript で同等の機能を提案できる人はいますか?

4

13 に答える 13

106

js の number_format に相当するものは、ここにあります

function number_format (number, decimals, dec_point, thousands_sep) {
    // Strip all characters but numerical ones.
    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);
}
于 2015-12-07T19:42:29.190 に答える
50

toLocaleString整数オブジェクトで使用するだけです。

https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Number/toLocaleString#Browser_compatibility

let x = 1234567;
//if x is a string/non-number, use parseInt/parseFloat to convert to a number. Thanks @Aleksandr Kopelevich
x.toLocaleString('us', {minimumFractionDigits: 2, maximumFractionDigits: 2})
于 2016-12-15T07:47:07.887 に答える
49

これはあなたが手に入れたいものですか?

yourFloatVarHere.toFixed(2);

ほら。

于 2013-01-15T19:16:22.013 に答える
19

ネイティブの「Intl」オブジェクト アプローチ:

var amount = 5000.25;
var locale = 'de';
var options = {style: 'currency', currency: 'eur', minimumFractionDigits: 2, maximumFractionDigits: 2};
var formatter = new Intl.NumberFormat(locale, options);

console.log(formatter.format(amount));

http://jsfiddle.net/arturrelax/sa9jL138/1/

詳細: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl

于 2014-12-12T08:01:52.537 に答える
12

PHPに近い機能はjavascriptにするnumber_format($number)必要がありますnumber.toLocaleString('en')

于 2020-01-17T22:08:27.033 に答える
3

これは、php で number_format とほぼ同じ結果を得るために使用できる単純な関数です。

function number_format(user_input){
    var filtered_number = user_input.replace(/[^0-9]/gi, '');
    var length = filtered_number.length;
    var breakpoint = 1;
    var formated_number = '';

    for(i = 1; i <= length; i++){
        if(breakpoint > 3){
            breakpoint = 1;
            formated_number = ',' + formated_number;
        }
        var next_letter = i + 1;
        formated_number = filtered_number.substring(length - i, length - (i - 1)) + formated_number; 

        breakpoint++;
    }

    return formated_number;
}

もう 1 つの方法は、ajax を使用して、数値に対して number_format を実行し、ajax を文字列として返す php スクリプトを呼び出すことです。しかし、それは少し面倒です。

于 2014-11-24T12:09:05.090 に答える
1

簡単ではありません。次のような単純な jquery-plugins を使用してみてください。

jquery-numberformatter

Jquery-価格-フォーマット

于 2012-10-10T13:24:48.860 に答える