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 :

[JS] Recupérer des valeurs d'input généré en php


Sujet :

JavaScript

  1. #1
    Membre confirmé
    Avatar de geforce
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2010
    Messages
    1 055
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2010
    Messages : 1 055
    Points : 559
    Points
    559
    Par défaut [JS] Recupérer des valeurs d'input généré en php
    Bonjour,

    je voudrai récupérai les valeur de champs (input) d'un tableaux construit dynamiquement en php.

    une partie du code php:

    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
    <?php
    for($r=0; $r< $countAnciente; $r++)  
       if (($ancientes[$r] != "TOTAL") && ($ages[$i] != "TOTAL"))  
      	{ $toto1 += $mat1[$j]['nbre'];  	 
          echo "<td><input name='tab".$r."".$i."' type='text' size='10' value='".$mat1[$j]['nbre']."' disabled='true' /> <input type='hidden' name='id_tab".$r."".$i."' value='".$mat1[$j++]['id']."' /></td>";
        }
        elseif (($ancientes[$r] != "TOTAL") && ($ages[$i] == "TOTAL")) 
         {
          echo "<td><input name='tabTotoColon' type='text' size='10' value='! solution JS?' /></td>";
         }
         elseif((($ancientes[$r] == "TOTAL") && ($ages[$i] != "TOTAL"))) { //echo "Toto : ".$toto."<br/>";echo "TotoLign : ".$totoLign."<br/>"; //$k --; $i--;
           echo "<td><input name='tabTotoLign' type='text' size='10' value='".$toto1."' /></td>";
           $totoLign += $toto1; $toto1 = 0;
          }
          else {
          	   echo "<td><input name='tabTotoDeToto' type='text' size='10' value='".$totoLign."' /></td>";	
               }
    code JS:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    function f()
    { 
     var obj = document.getElementsByName('tab00');
      alert('le champ a pour valeur : "'+obj.value+"'");
    }
    je fait un appel à la fonction sur l’évènement:
    j'ai toujours la valeur "undefined" comme si le JS s’exécute avant le php (c'est un peut normale) mais comment faire pour que ce soit le contraire ?

    cordialement
    GeForce

  2. #2
    Modérateur

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

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 120
    Points : 44 910
    Points
    44 910
    Par défaut
    Bonjour,
    la méthode getElementsByName renvoie une nodeList, tu auras remarqué le S après Element.

    Ceci veut dire que lorsque tu fais obj.value tu demandes la value de la nodeList qui n'existe effectivement pas, il te faut faire appel aux différents élément de cette nodeList comme on le fait pour un tableau donc
    - obj[0].value pour le premier élément
    - obj[1].value pour le deuxième élément
    et ainsi de suite

    Nota:
    si tu n'as qu'un élément qui a le même name tu peux également passer par la méthode getElementById

  3. #3
    Membre confirmé
    Avatar de geforce
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2010
    Messages
    1 055
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2010
    Messages : 1 055
    Points : 559
    Points
    559
    Par défaut
    Bonjour,

    je voudrai savoir s'il existe une solution pour faire à appel à une fonction JS (pure, sans framework) de la façon suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    window.orig_onload = window.onload;
    window.onload = function() {....}
    sans utiliser :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <body onload="function();">
    c'est pour être sûr que le JS ne s’exécute pas avant le chargement de la page et l’exécution du php.

    merci d'avance

    Cordialement
    GeForce

  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
    c'est pour être sûr que le JS ne s’exécute pas avant le chargement de la page et l’exécution du php.
    ?

    heu php est toujours exécuté AVANT le js ...

  5. #5
    Membre confirmé
    Avatar de geforce
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2010
    Messages
    1 055
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2010
    Messages : 1 055
    Points : 559
    Points
    559
    Par défaut
    Citation Envoyé par SpaceFrog Voir le message
    ?
    heu php est toujours exécuté AVANT le js ...
    oui, mais le JS peut s’exécuter avant le chargement du HTML, c'est pour sa que il faut que j'utilise mais donne met page je n'est pas body (dans cette page)

    c'est pour sa que je cherche l’équivalent en JS ?

  6. #6
    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
    une page sans body ???

    c'est une erreur de codage ça ne doit pas exister !

  7. #7
    Membre confirmé
    Avatar de geforce
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2010
    Messages
    1 055
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2010
    Messages : 1 055
    Points : 559
    Points
    559
    Par défaut
    Citation Envoyé par SpaceFrog Voir le message
    une page sans body ???

    c'est une erreur de codage ça ne doit pas exister !
    le ficher est include dans un autre qui lui à un Body ?

  8. #8
    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
    alors le onload convient .
    il faut juste utiliser une astuce de surcharge du onload car si je te susi bien, au moment ou tu fais l'include la blaise body est déja rédigée par php et tu ne peux pas l'anticiper ?

  9. #9
    Expert éminent
    Avatar de sekaijin
    Homme Profil pro
    Urbaniste
    Inscrit en
    Juillet 2004
    Messages
    4 205
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Urbaniste
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2004
    Messages : 4 205
    Points : 9 127
    Points
    9 127
    Par défaut
    1) ajouter un id sur l'élément input
    Code php : 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
    for($r=0; $r< $countAnciente; $r++) {
      if (($ancientes[$r] != "TOTAL") && ($ages[$i] != "TOTAL"))
      { $toto1 += $mat1[$j]['nbre'];
        echo "<td><input id='tab".$r.$i."' name='tab".$r.$i."' type='text' size='10' value='".$mat1[$j]['nbre']."' disabled='true' /> <input type='hidden' name='id_tab".$r."".$i."' value='".$mat1[$j++]['id']."' /></td>";
      }
      elseif (($ancientes[$r] != "TOTAL") && ($ages[$i] == "TOTAL"))
      {
        echo "<td><input name='tabTotoColon' type='text' size='10' value='! solution JS?' /></td>";
      }
      elseif((($ancientes[$r] == "TOTAL") && ($ages[$i] != "TOTAL"))) { //echo "Toto : ".$toto."<br/>";echo "TotoLign : ".$totoLign."<br/>"; //$k --; $i--;
        echo "<td><input name='tabTotoLign' type='text' size='10' value='".$toto1."' /></td>";
        $totoLign += $toto1; $toto1 = 0;
      }
      else {
        echo "<td><input name='tabTotoDeToto' type='text' size='10' value='".$totoLign."' /></td>";
      }
    }
    2) utiliser getElementById et non getElementsByNames
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    myNS={
      func : function () {
        var obj = document.getElementsById('tab00');
        if obj {
          alert('le champ a pour valeur : "'+obj.value+"'");
        }
      }
    }
    3) utiliser le gestionnaire d'évènement pour ajouter la fonction au onload sans supprimer celle qui y sont déja
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    #ajouter la fonction au onload
    if (window.addEventListener) {
      window.addEventListener("load", myNS.func, false);
    } else if (document.addEventListener) {
      document.addEventListener("load", myNS.func, false);
    } else if (window.attachEvent) {
      window.attachEvent("onload", myNS.func);
    }
    A+JYT

  10. #10
    Modérateur

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

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 120
    Points : 44 910
    Points
    44 910
    Par défaut
    Citation Envoyé par sekaijin Voir le message
    2) utiliser getElementById et non getElementsByNames
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    myNS={
      func : function () {
        var obj = document.getElementsById('tab00');
        if obj {
          alert('le champ a pour valeur : "'+obj.value+"'");
        }
      }
    }
    A+JYT
    Attention erreur de frappe dans le code ci dessus pas de S dans getElementById
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    var obj = document.getElementById('tab00');

  11. #11
    Membre confirmé
    Avatar de geforce
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2010
    Messages
    1 055
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2010
    Messages : 1 055
    Points : 559
    Points
    559
    Par défaut
    Citation Envoyé par sekaijin Voir le message
    3) utiliser le gestionnaire d'évènement pour ajouter la fonction au onload sans supprimer celle qui y sont déja
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    #ajouter la fonction au onload
    if (window.addEventListener) {
      window.addEventListener("load", myNS.func, false);
    } else if (document.addEventListener) {
      document.addEventListener("load", myNS.func, false);
    } else if (window.attachEvent) {
      window.attachEvent("onload", myNS.func);
    }
    Ok, merci sa marche Mais j'ai pas bien comprit la différence entre chaque if ? (si possible d'expliquer un peut)

    merci d'avance

  12. #12
    Expert éminent
    Avatar de sekaijin
    Homme Profil pro
    Urbaniste
    Inscrit en
    Juillet 2004
    Messages
    4 205
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Urbaniste
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2004
    Messages : 4 205
    Points : 9 127
    Points
    9 127
    Par défaut
    Citation Envoyé par geforce Voir le message
    Ok, merci sa marche Mais j'ai pas bien comprit la différence entre chaque if ? (si possible d'expliquer un peut)

    merci d'avance
    l'évènement load est définit dans documentElement du DOM
    mais la norme HTTP ne di(sai)t pas si l'attribut onload de l'élément Body correspond à l'objet document ou à l'objet window de plus sa gestion est antérieure à la spécification du W3C
    on a donc suivant les navigateurs l'événement sur window ou sur document
    et pour couronner le tout deux méthodes (toujours en fonction du navigateur)
    addEventListener qui prend comme nom d'événement load
    et
    attachEvent qui prend comme nom d'événement onload

    ce petit code teste donc l'existence des différentes méthodes sur les différents objet pour savoir la quelle utiliser

    A+JYT

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

Discussions similaires

  1. [JDOM] recupérer des valeurs d'un fichier xml
    Par legendaire dans le forum Format d'échange (XML, JSON...)
    Réponses: 3
    Dernier message: 05/02/2008, 16h21
  2. Recupération des valeurs des checkbox
    Par goosweb dans le forum Général VBA
    Réponses: 1
    Dernier message: 10/07/2007, 20h40
  3. Récuperer la valeur d'input généré dynamiquement
    Par pivalone dans le forum Général JavaScript
    Réponses: 9
    Dernier message: 26/06/2007, 14h45
  4. Recupérer des valeurs perdues
    Par bounnitcharaf dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 17/10/2006, 09h36
  5. [VB.NET][2.0]recupérer des valeurs d'un bindingsource
    Par Golzinne dans le forum Windows Forms
    Réponses: 1
    Dernier message: 29/03/2006, 18h43

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