IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

JavaScript Discussion :

Round valeur de réponse ?


Sujet :

JavaScript

  1. #1
    Membre à l'essai
    Femme Profil pro
    Collégien
    Inscrit en
    Février 2019
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 39
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Collégien

    Informations forums :
    Inscription : Février 2019
    Messages : 27
    Points : 19
    Points
    19
    Par défaut Round valeur de réponse ?
    bonjour à tous

    j'aurais besoin que vous m'éclairiez sur mon code, j'essaie simplement de faire soit un Math.round ou un .tojustify(2) à 2 décimal après le sur la reponse qui sort dans ma boite bleu.

    Exemple: Watt dans la première boite ( 30 ) et dans la 2e mettez ( 6 ) Résultat brute est : 6.989700043360188 dB, mais j'aimerais uniquement y voir 6.99 dB et aucun des deux ne semble fonctionner peut importe ou je le situe dans le code.

    Qu'est-ce que je fais de pas correcte ?


    https://jsfiddle.net/ameo0dyr/

    Merci

  2. #2
    Expert éminent sénior
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 409
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 409
    Points : 15 778
    Points
    15 778
    Par défaut
    pour le formatage de nombres j'utilise la fonction dont j'ai mis le code en fin de message.
    appliquée à votre exemple, cela donne ça :
    https://jsfiddle.net/3vhq97ux/

    P.S. : n'utilisez pas cette fonction, regardez là :
    https://www.developpez.net/forums/d2.../#post11776395

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    function formatNombre2Chiffres(nStr) {
     
    	nStr = nStr.toFixed(2);
    	nStr += '';
     
    	let x = nStr.split('.');
     
    	let x1 = x[0];
    	let x2 = x.length > 1 ? ',' + x[1] : ',00';
     
     
    	let rgx = /(\d+)(\d{3})/;
     
    	while (rgx.test(x1)) {
    		x1 = x1.replace(rgx, '$1' + ' ' + '$2');
    		//x1 = x1.replace(rgx, '$1\u202F$2');
    	}
     
    	return x1 + x2;
     
    }

  3. #3
    Expert confirmé
    Avatar de Doksuri
    Profil pro
    Développeur Web
    Inscrit en
    Juin 2006
    Messages
    2 476
    Détails du profil
    Informations personnelles :
    Âge : 54
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 476
    Points : 4 687
    Points
    4 687
    Par défaut
    sinon, il existe "l'internationalisation" des nombres (comme les dates)
    developer.mozilla.org/fr/docs/Web/JavaScript/Reference/Global_Objects/Intl/NumberFormat

  4. #4
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 108
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 108
    Points : 44 921
    Points
    44 921
    Par défaut
    Bonjour,
    un nombre.toFixed(nbDecimales) ne serait pas suffisant ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    const result = (Math.log10(outwatt1 / outwatt2)) * 10;
    elemResult.textContent = result.toFixed(2) + " DB";

  5. #5
    Expert éminent sénior
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 409
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 409
    Points : 15 778
    Points
    15 778
    Par défaut
    bien vu Doksuri, je n'étais pas à jour. il y a encore 1 ou 2 ans (je ne suis plus du tout sur de la date) il y a avait un souci avec le séparateur des milliers en français avec firefox.
    et là je viens de tester et ce souci est réglé donc la fonction que j'ai mise dans mon message au dessus peut être oubliée.

    donc là pour afficher un arrondi à 2 chiffres derrière la virgule en respectant les règles de typographie, on peut faire ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    let affichage = new Intl.NumberFormat("fr-FR", {
    	"style" : "decimal",
    	"minimumFractionDigits" : 2,
    	"maximumFractionDigits" : 2,
    }).format(calcul) + " dB";
    https://jsfiddle.net/7dztuoes/

  6. #6
    Membre à l'essai
    Femme Profil pro
    Collégien
    Inscrit en
    Février 2019
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 39
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Collégien

    Informations forums :
    Inscription : Février 2019
    Messages : 27
    Points : 19
    Points
    19
    Par défaut
    wow Merci j'avais pas vu ca comme ca !

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [XL-2016] histogramme sur valeurs de réponse
    Par melaphen dans le forum Excel
    Réponses: 4
    Dernier message: 09/08/2016, 17h58
  2. Réponses: 2
    Dernier message: 20/05/2016, 17h06
  3. [XL-2007] valeur dans inputbox et gestion des réponses ok cancel
    Par LaMite dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 16/05/2014, 12h58
  4. Réponses: 4
    Dernier message: 20/09/2013, 09h57
  5. [AJAX] Autocomplete avec paire clé / valeur, réponse en xml
    Par flozza dans le forum jQuery
    Réponses: 7
    Dernier message: 02/02/2013, 00h56

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo