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 :

[DOM] Tableau de calcul en javascript


Sujet :

JavaScript

Vue hybride

Message pr�c�dent Message pr�c�dent   Message suivant Message suivant
  1. #1
    Membre confirm�
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    121
    D�tails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 121
    Par d�faut [DOM] Tableau de calcul en javascript
    Bonjour,

    j'ai besoin de vos lumi�res pour un exercice :

    Je souhaiterais faire un tableau o� on aurait un produit (avec un prix et un poids d�fini dans deux colonnes distinctes), on choisit la quantit� dans une autre colonne et dans les deux derni�res on y trouve le poids total et le prix total (suivant la quantit� choisie).

    Je me sers de la formule suivante :
    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    <head>
    <script language="javascript"> 
    function popbs() { window.document.formulaire.ptpb.value = document.formulaire.popb.value * 370 ; } 
    function prpbs() { window.document.formulaire.prtpb.value = document.formulaire.popb.value * 6 ; }
    </script> 
    </head>
    <body>
        <td align="center"><input type="text" name="popb" size="3" onkeyup="popbs()"> </td>
        <td align="center"><input type="text" name="ptpb" size="8" disabled="disabled" > g</td>
        <td align="center"><input type="text" name="prtpb" size="8" disabled="disabled" > g</td>
    </body>
    J'arrive � faire le premier calcul : celui qui fait : quantit�x370g = poids total
    Mais impossible de faire l'autre. En fait, c'est que je n'arrive pas � combiner deux fonctions pour un formulaire : quand je les mets s�prament �a va... Comment faire en sorte que la case pour la quantit� soit utilis�e pour deux calculs ?

    Merci

  2. #2
    Expert confirm�
    Avatar de Auteur
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    7 660
    D�tails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 7 660
    Par d�faut
    bonjour,

    La valeur contenue dans un input (quel qu'il soit) ou un textarea est une chaine de caract�res. Donc il faut transformer cette chaine en nombre en utilisant parseInt() ou parseFloat() :

    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
     
    document.formulaire.ptpb.value = parseFloat(document.formulaire.popb.value) * 370 ;

  3. #3
    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 659
    D�tails du profil
    Informations personnelles :
    Sexe : Homme
    �ge : 75
    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 659
    Billets dans le blog
    1
    Par d�faut
    il sera aussi plus �l�gant (et crossbrowser) d'utiliser une syntaxe plus correcte:

    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    document.forms['formulaire'].elements['ptpb'].value
    n'oublie pas de preciser �galement la base du parse (par defaut sous IE par exemple elle est � 8)
    Ma page Developpez - Mon Blog Developpez
    Pr�sident du CCMPTP (Comit� Contre le Mot "Probl�me" dans les Titres de Posts)
    Deux r�gles du succ�s: 1) Ne communiquez jamais � quelqu'un tout votre savoir...
    Votre post est r�solu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de D�veloppez !

  4. #4
    Expert confirm�
    Avatar de Auteur
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    7 660
    D�tails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 7 660
    Par d�faut
    [QUOTE=SpaceFrog;4119782]il sera aussi plus �l�gant (et crossbrowser) d'utiliser une syntaxe plus correcte:

    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    document.forms['formulaire'].elements['ptpb'].value
    ou document.getElementById() ;=

    Citation Envoy� par SpaceFrog Voir le message
    n'oublie pas de preciser �galement la base du parse (par defaut sous IE par exemple elle est � 8)
    IE travaille en base 8 . J'aurai appris quelque chose
    Maintenant si mariepierre utilise parseFloat() je ne pense pas qu'il faille pr�ciser la base

  5. #5
    R�dacteur

    Avatar de Bovino
    Homme Profil pro
    D�veloppeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    D�tails du profil
    Informations personnelles :
    Sexe : Homme
    �ge : 55
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activit� : D�veloppeur Web
    Secteur : High Tech - �diteur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par d�faut
    Citation Envoy� par SpaceFrog Voir le message
    (par defaut sous IE par exemple elle est � 8)
    Uniquement si le chiffre en question commence par 0 il me semble ?
    Pas de question technique par MP !
    Tout le monde peut participer � developpez.com, vous avez une id�e, contactez-moi !
    Mes formations video2brain : La formation compl�te sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'int�gration de JSFiddle et CodePen sur le forum

  6. #6
    Membre confirm�
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    121
    D�tails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 121
    Par d�faut
    merci pour vos r�ponses, cependant cela ne marche toujours pas :

    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
     
     
    function popbs() { window.document.formulaire.ptpb.value = parseFloat(document.formulaire.popb.value) * 370 ; } 
    function prpbs() { window.document.formulaire.prtpb.value = document.formulaire.popb.value * 6 ; }
     
     
    <tr bgcolor="#f6f1e0">
        <td><img src=" "></td>
        <td><strong>Petit brebis</strong></td>
        <td align="center">370g</td>
        <td align="center">6,00 €</td>
        <td align="center"><input type="text" name="popb" size="3" onkeyup="popbs()" onKeyUp="prpbs()"> </td>
        <td align="center"><input type="text" name="ptpb" size="8" disabled="disabled" onkeyup="pts()" > g</td>
        <td align="center"><input type="text" name="prtpb" size="8" disabled="disabled" > euros</td>
      </tr>
    C'est au niveau de la gestion de deux fonctions non qu'il y a un probl�me ?

  7. #7
    R�dacteur

    Avatar de Bovino
    Homme Profil pro
    D�veloppeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    D�tails du profil
    Informations personnelles :
    Sexe : Homme
    �ge : 55
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activit� : D�veloppeur Web
    Secteur : High Tech - �diteur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par d�faut
    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    <td align="center"><input type="text" name="popb" size="3" onkeyup="popbs();prpbs()"> </td>
    si tu mets 2 fois onkeyup, le 2e annule le 1er
    Pas de question technique par MP !
    Tout le monde peut participer � developpez.com, vous avez une id�e, contactez-moi !
    Mes formations video2brain : La formation compl�te sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'int�gration de JSFiddle et CodePen sur le forum

  8. #8
    Membre confirm�
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    121
    D�tails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 121
    Par d�faut
    Re moi.

    maintenant j'ai un probl�me pour envoyer le r�sultat des champs automatiques via un script d'envoi basique en php.

    �a coince avec le "disabled" (qu'il ait en propri�t� "disabled" ou "read only").
    quand je l'enl�ve �a va... mais je suis oblig�e de le laisser sinon le r�sultat est modifiable

  9. #9
    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 659
    D�tails du profil
    Informations personnelles :
    Sexe : Homme
    �ge : 75
    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 659
    Billets dans le blog
    1
    Par d�faut
    jette un oeil sur les champs hidden ...
    Ma page Developpez - Mon Blog Developpez
    Pr�sident du CCMPTP (Comit� Contre le Mot "Probl�me" dans les Titres de Posts)
    Deux r�gles du succ�s: 1) Ne communiquez jamais � quelqu'un tout votre savoir...
    Votre post est r�solu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de D�veloppez !

  10. #10
    Membre confirm�
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    121
    D�tails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 121
    Par d�faut
    Citation Envoy� par SpaceFrog Voir le message
    jette un oeil sur les champs hidden ...
    je ne comprends pas

  11. #11
    Expert confirm�
    Avatar de Auteur
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    7 660
    D�tails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 7 660
    Par d�faut
    Tu as des input de type hidden :
    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    <input type="hidden" value="valeur cachée" id="inputHidden" />
    Tu peux y placer tout ce que tu veux : par exemple le r�sultat interm�diaire d'un calcul.
    Ces champs ont la particularit� d'�tre cach�s, ils sont totalement invisibles sur la page.

  12. #12
    Membre confirm�
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    121
    D�tails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 121
    Par d�faut
    on peut y placer le r�sultat d'un calcul automatique ?

Discussions similaires

  1. petit calcul en Javascript
    Par Dream Time dans le forum G�n�ral JavaScript
    R�ponses: 2
    Dernier message: 01/03/2007, 02h07
  2. [DOM] tableau et javascript
    Par franfr57 dans le forum G�n�ral JavaScript
    R�ponses: 18
    Dernier message: 20/12/2006, 16h46
  3. Passer un tableau de VbScript vers Javascript
    Par Poussy-Puce dans le forum ASP
    R�ponses: 1
    Dernier message: 03/03/2006, 12h07
  4. R�ponses: 10
    Dernier message: 19/01/2006, 06h41
  5. Tableau et calculs
    Par isak dans le forum Composants
    R�ponses: 1
    Dernier message: 30/06/2005, 10h33

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