web-dev-qa-db-fra.com

Équivalent à PHP fonction number_format dans jquery/javascript

Fonction PHP:

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

Mon besoin: Tout organisme peut-il me suggérer la fonctionnalité équivalente dans jQuery/javascript 

Merci d'avance.

48
RAVI MONE

est-ce ce que vous souhaitez obtenir?

yourFloatVarHere.toFixed(2);

voilà.

40
MoVod

Le même équivalent de number_format dans js peut être trouvé ici

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);
}
56
Umair Hamid

Utilisez simplement toLocaleString sur un objet entier.

https://developer.mozilla.org/fr/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})
18
Ahmed-Anas

Approche objet "Intl" native:

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/

Plus d'informations sur: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl

10
Artur Beljajev

Je sais que c'est un vieux fil, mais j'ai créé ma propre fonction, qui est en Javascript pur.

https://Gist.github.com/VassilisPallas/d73632e9de4794b7dd10b7408f7948e8

function number_format(number, decimals, dec_point, thousands_point) {

    if (number == null || !isFinite(number)) {
        throw new TypeError("number is not valid");
    }

    if (!decimals) {
        var len = number.toString().split('.').length;
        decimals = len > 1 ? len : 0;
    }

    if (!dec_point) {
        dec_point = '.';
    }

    if (!thousands_point) {
        thousands_point = ',';
    }

    number = parseFloat(number).toFixed(decimals);

    number = number.replace(".", dec_point);

    var splitNum = number.split(dec_point);
    splitNum[0] = splitNum[0].replace(/\B(?=(\d{3})+(?!\d))/g, thousands_point);
    number = splitNum.join(dec_point);

    return number;
}

https://jsfiddle.net/htyxfra9/2/

9
Vassilis Pallas

Voici une autre solution courte qui devrait se comporter comme l’équivalent php.

function number_format(number,decimals,dec_point,thousands_sep) {
    number  = number*1;//makes sure `number` is numeric value
    var str = number.toFixed(decimals?decimals:0).toString().split('.');
    var parts = [];
    for ( var i=str[0].length; i>0; i-=3 ) {
        parts.unshift(str[0].substring(Math.max(0,i-3),i));
    }
    str[0] = parts.join(thousands_sep?thousands_sep:',');
    return str.join(dec_point?dec_point:'.');
}
4
Dennis Bohn

Voici une fonction simple que vous pouvez utiliser pour obtenir presque le même résultat de number_format en php:

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;
}

Une autre solution consiste à utiliser ajax pour appeler un script php dans lequel vous exécutez number_format sur le nombre et le renvoyez avec ajax sous forme de chaîne. Mais c'est un peu brouillon.

3
spreadzz

Ce n’est pas facile, essayez d’utiliser des plugins jquery simples tels que:

jquery-numberformatter

Jquery-Price-Format

2
RDK

Je dois le faire en appelant simplement la fonction JS comme suit et cela fonctionne:

var formattedNumber = number_format(value)
1
Ajju

Mon point de vue sur ceci:

var number_format = function(num) {
  stringNum = num.toString();
  stringNum = stringNum.split("");
  c = 0;
  if (stringNum.length>3) {
    for (i=stringNum.length; i>-1; i--) {
      if ( (c==3) && ((stringNum.length-i)!=stringNum.length) ) {
        stringNum.splice(i, 0, ",");
        c=0;
      }
      c++
    }
    return stringNum;
  }
  return num;
}

$("body").append(number_format(100000000));
0
Nir Tzezana

Une autre variante des exemples exposés:

const numberFormat = (value, decimals, decPoint, thousandsSep) => {
    decPoint = decPoint || '.';
    decimals = decimals !== undefined ? decimals : 2;
    thousandsSep = thousandsSep || ' ';

    if (typeof value === 'string') {
        value = parseFloat(value);
    }

    let result = value.toLocaleString('en-US', {
        maximumFractionDigits: decimals,
        minimumFractionDigits: decimals
    });

    let pieces = result.split('.');
    pieces[0] = pieces[0].split(',').join(thousandsSep);

    return pieces.join(decPoint);
};

C'est la fonction number_format en javascript comme PHP:

function number_format(number) {
    var isFloat = false;
    var main = number;
    var floatValue = '';
    if(number.indexOf('.') != -1) {
        var s = number.split('.');
        main = s[0];
        floatValue = s[1];
        isFloat = true;
    }
    var length = main.length;
    if(length > 3) {
        var format = '';
        var counter = 0;
        for(var i = length - 1; i >= 0; i--) {
            format += main[i];
            counter++;
            if(counter == 3) {
                format += ",";
                counter = 0;
            }
        }
        var r = format.split('').reverse().join('');
        if(isFloat) {
            r += '.' + floatValue;
        }
        return r;
    } else {
        return number;
    }
}
0
Ebrahim Fallah