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 :

la conversion de poids


Sujet :

JavaScript

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2011
    Messages
    131
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Mars 2011
    Messages : 131
    Points : 49
    Points
    49
    Par défaut la conversion de poids
    Bonjour,

    je ne suis pas très doué avec le javascript.

    J'ai 2 champs un le kg, l'autre la livre.

    Si j'actualise la livre, il actualise le poids et inversement si j'actualise le poids, il actualise la livre.

    J'ai un problème, lorsque que j'écris 0.002 kg pour le convertir en livre, automatiquement il me refuse l'écriture. En fait dès que je mets un . , il refuse que je continue d'insérer le poids ex : 5.02

    J'arrive pas trouver le problème pour le résoudre.

    Pouvez vous m'aider ?

    Merci beaucoup

    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
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
     
    <!------------------------->
    <!-- convertisseur poids -->
    <!------------------------->
    <script type="text/javascript"><!--
    function forceValidFloat(n) {
        if(n.length == 0) return '';
        var valids = '0123456789';
        var hasDot = false;
        var r = '';
        var c;
        for(var i = 0; i < n.length; ++i)  {
            c = n.charAt(i);
            if(c == '-' && r.length == 0) {
                r += '-';
            }
            else if((c == '.' || c == ',') && !hasDot) {
                r += (r.length == 0 || r == '-') ? '0.' : '.';
                hasDot = true;
            }
            else if(valids.indexOf(c) != -1)  {
                r += c;
            }
        }
     
        return r;
    }
     
    function convertCtoF() {
        document.forms["new_product"].products_weight_pounds.value = '';
        document.forms["new_product"].products_weight.value = forceValidFloat(document.forms["new_product"].products_weight.value);
        if(document.forms["new_product"].products_weight.value.length < 0 ||
           document.forms["new_product"].products_weight.value == '-' ||
           document.forms["new_product"].products_weight.value == '-0' ||
           document.forms["new_product"].products_weight.value == '-0.') return;
     
        if(document.forms["new_product"].products_weight.value.charAt(document.forms["new_product"].products_weight.value.length-1) != '.')
            document.forms["new_product"].products_weight.value = document.forms["new_product"].products_weight.value%10000;
        var temp = (parseFloat(document.forms["new_product"].products_weight.value)/0.45359237).toPrecision(4);
        while(temp.indexOf('.') != -1 && (temp.charAt(temp.length-1) < '0' || temp.charAt(temp.length-1) == '.'))
            temp = temp.substr(0, temp.length-1);
        document.forms["new_product"].products_weight_pounds.value = temp;
    }
     
    function convertFtoC() {
        document.forms["new_product"].products_weight.value = '';
        document.forms["new_product"].products_weight_pounds.value = forceValidFloat(document.forms["new_product"].products_weight_pounds.value);
        if(document.forms["new_product"].products_weight_pounds.value.length == 0 ||
           document.forms["new_product"].products_weight_pounds.value == '-' ||
           document.forms["new_product"].products_weight_pounds.value == '-0' ||
           document.forms["new_product"].products_weight_pounds.value == '-0.') return;
        if(document.forms["new_product"].products_weight_pounds.value.charAt(document.forms["new_product"].products_weight_pounds.value.length-1) != '.')
            document.forms["new_product"].products_weight_pounds.value = document.forms["new_product"].products_weight_pounds.value%10000;
        var temp = ((parseFloat(document.forms["new_product"].products_weight_pounds.value)*0.45359237)).toPrecision(4);
        while(temp.indexOf('.') != -1 && (temp.charAt(temp.length-1) < '0' || temp.charAt(temp.length-1) == '.'))
            temp = temp.substr(0, temp.length-1);
        document.forms["new_product"].products_weight.value = temp;
    }
    //--></script>

  2. #2
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 640
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 640
    Points : 66 665
    Points
    66 665
    Billets dans le blog
    1
    Par défaut
    Je te conseillerais plutot de te pencher sur les validation par expression régulières:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    /(-?\d+([.,]\d+)?)\s?(kg)?/
    celle ci te permet par exemple de valider
    1
    1kg
    1 kg
    1.0kg
    1.0 kg
    -1
    -1 kg
    -1.002
    -1.002kg
    -1.002kg

    et de recupérer la valeur de float en $1 (premier niveau de parenthèses)

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2011
    Messages
    131
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Mars 2011
    Messages : 131
    Points : 49
    Points
    49
    Par défaut
    désolé mais je ne suis pas trop.

  4. #4
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 640
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 640
    Points : 66 665
    Points
    66 665
    Billets dans le blog
    1
    Par défaut
    planche là dessus
    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
    22
    23
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=windows-1252">
    <script type="text/javascript">
    function verif()  {
    val=document.getElementById('foo').value
    if (val==''){alert('saisie vide'); return false;}
    reg=/^(-?\d+([.,]\d+)?)\s?(kg)?$/i
    bool=val.match(reg)
    if (!bool) {alert( "erreur de saisie"); res=null }
    else {
    alert ('votre saisie '+bool[1] + ' est correcte')}
    res=bool[1].replace(',','.')*1
    alert (res)
    }
    </script>
    <title>Nouvelle page 1</title>
    </head>
    <body>
    <input type='texte' id="foo" value="" />
    <input type ="button" onclick="verif()" value="check" />
    </body>
    </html>

Discussions similaires

  1. Réponses: 5
    Dernier message: 26/12/2012, 10h52
  2. Conversion poids IDOC DESADV
    Par beuzy dans le forum SAP
    Réponses: 4
    Dernier message: 30/08/2012, 16h09
  3. Algorithme de conversion de RTF vers HTML
    Par youtch dans le forum Algorithmes et structures de données
    Réponses: 10
    Dernier message: 10/09/2002, 12h35
  4. [Conversions] Millisecondes...
    Par agh dans le forum Langage
    Réponses: 2
    Dernier message: 06/08/2002, 11h25
  5. Réponses: 2
    Dernier message: 05/06/2002, 12h29

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