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 :

Récuperer la valeur d'input généré dynamiquement


Sujet :

JavaScript

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    17
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 17
    Points : 6
    Points
    6
    Par défaut Récuperer la valeur d'input généré dynamiquement
    Bonjour,

    Je génère dynamiquement l'affichage d'une liste en php et je souhaiterais vérifier que la valeur d'input portant le même nom n'est pas égale à 0.

    Je m'explique:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    <tr> 
    <td class="td" width="65"><?php print $val['Nom']; ?></td>
    <td class="td" width="65"><?php print $val['Prenom']; ?></td>
    <td class="td" width="65"><?php print $val['Age']; ?></td>
    <td class="td" width="65"><input type="text" id="genre" size="4" value="0"></td>
    </tr>
    Les informations sont extraites de ma base sauf pour "genre" où elle doit être saisie.

    J'ai 10 personnes dans ma base et j'ai donc 10 fois le champs "genre" qui va s'afficher.

    Je souhaite vérifier en javascript que tous les champs "genre" ne sont pas vides.

    J'ai vérifié comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    function checkGenre()
    {
     
     if(document.getElementById('genre') == "")
      {
       alert("\nVous avez oublié de saisir le genre!\n");
       return false;
      }
    document.form.submit();
    }
    mais il ne vérifie qu'un seul champ "genre" et pas tous les champs "genre" donc le formulaire va se valider avec des champ "genre" vides?

    Je ne trouve pas la méthode.

    Merci pour votre aide

  2. #2
    Expert confirmé
    Avatar de javatwister
    Homme Profil pro
    danseur
    Inscrit en
    Août 2003
    Messages
    3 681
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : danseur

    Informations forums :
    Inscription : Août 2003
    Messages : 3 681
    Points : 5 221
    Points
    5 221
    Par défaut
    l'attribut id est unique dans une page html; utilise la propriété name et appelle le tableau document.getElementsByname()

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    17
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 17
    Points : 6
    Points
    6
    Par défaut
    Qu'entends-tu par récupères le tableau?

    Si je remplace
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    getElementById('genre').value
    par
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    getElementsByName('genre').value
    l'alerte ne fonctionne pas.

  4. #4
    Futur Membre du Club
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    17
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 17
    Points : 6
    Points
    6
    Par défaut
    J'ai compris pour le tableau, il faudrait que cela ressemble à çà:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    function checkGenre()
    {
     
     if(document.getElementsByName('genre')[0] == "")
      {
       alert("\nVous avez oublié de saisir le genre!\n");
       return false;
      }
    document.form.submit();
    }
    mais il me reste un problème car comme cela je ne vérifie toujours pas tous mes champs. Il faudrait donc que cela ressemble à qqch comme çà:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    function checkGenre()
    {
     
     if(document.getElementsByName('genre')[i] == "")
      {
       alert("\nVous avez oublié de saisir le genre!\n");
       return false;
      }
    document.form.submit();
    }
    Mais il me manque encore qqch!

  5. #5
    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
    rien à voir ... mais déja sans faute c'est mieux :


    Vous avez oublié de saisir le genre!

  6. #6
    Futur Membre du Club
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    17
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 17
    Points : 6
    Points
    6
    Par défaut
    La faute est corrigée.

    Effectivement cela ne fonctionne pas mais je n'ai pas de piste.

  7. #7
    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
    il y a un post dasn les ancioennes contributions ... une petite recherche te donnera la solution ...

    et pour la piste ...

    dans ta fonction ... i vaut quoi ???
    faudrait peut être une boucle pour l'incrémenter non ?

  8. #8
    Futur Membre du Club
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    17
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 17
    Points : 6
    Points
    6
    Par défaut
    En fait si je fais comme ça cela fonctionne :

    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 checkGenre()
    {
     
      for (i=0; i<16; i++) 
      { 
         if(document.getElementsByName('genre')[i].value == "0")
         {
         alert("\Vous avez oublié de saisir le genre!\n");
         return false;
         }
      } 
    document.formulaire.submit();
     
    }
    Mais cela suppose que je connais le nombre de fois que le champ "genre" va être présent. Or je ne le connais pas car ma liste va s'agrandir ou diminuer.

    Comment puis-je compter le nb de fois où le champ est présent?

  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 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
    regarde un tour de magie

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    alert(document.getElementsByName('Quantite').length)

  10. #10
    Futur Membre du Club
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    17
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 17
    Points : 6
    Points
    6
    Par défaut
    J'ai trouvé. C'est une piste que j'avais exploré mais en utilisant getElementById et forcément cela ne pouvait pas marcher.

    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
     
    function checkGenre()
    {
     
     var tab = document.getElementsByName('genre');
     var lengthTab = tab.length;
     
     for (i=0; i<lengthTab; i++) 
     {
        if(document.getElementsByName('genre')[i].value == "0")
         {
         alert("\Vous avez oublié de saisir le genre!\n");
         return false;
         }
     } 
     
    document.formulaire.submit();
    }
    Merci.

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 27/02/2015, 21h23
  2. récupération des valeurs d'un input généré dynamiquement
    Par patheo2 dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 16/03/2011, 16h07
  3. [JS] Recupérer des valeurs d'input généré en php
    Par geforce dans le forum Général JavaScript
    Réponses: 11
    Dernier message: 18/01/2011, 20h52
  4. Récuperer la valeur d'un RadioButton dynamique
    Par sisi87 dans le forum ASP.NET
    Réponses: 4
    Dernier message: 20/09/2010, 15h52
  5. Récupérer la valeur de champs générés dynamiquement
    Par dedeloux dans le forum Général JavaScript
    Réponses: 9
    Dernier message: 22/04/2008, 22h00

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