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] Nommer mes zones de texte créées dynamiquement par javascript


Sujet :

JavaScript

  1. #1
    Membre éprouvé
    Avatar de beegees
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2004
    Messages
    3 610
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Enseignement

    Informations forums :
    Inscription : Mars 2004
    Messages : 3 610
    Points : 1 277
    Points
    1 277
    Par défaut [DOM] Nommer mes zones de texte créées dynamiquement par javascript
    Bonjour tout le monde,

    J'ai un script javascript qui me permet de créer une ligne dans un tableau et d'y insérer n text area (zone de texte) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    $NbFields = mysql_num_fields($query);
    		echo 'le nombre de champ de cette table vaut ' . $NbFields;
    		echo  '<input type="button" value="Ajouter une ligne au tableau" onClick="AddRow('.$NbFields.') "; >';
     
    		echo '</table>';
     
    		?>
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    <script type="text/javascript">
    function AddRow(NombreCellules)
    {
         var newRow = document.getElementById('TableauUpdate').insertRow(-1); //on ajoute une ligne en fin de tableau
      for(i = 0; i < NombreCellules; i++)
      {
        var input = document.createElement("input");
        input.type = "text";
        newCell = newRow.insertCell(i);
        newCell.appendChild(input);
      }
    }
    </script>
    Je devrais donner un nom bien précis à chaque zone de texte créés.

    Voici ce que cela devrait donner :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <td> <textarea name="new[2][NOM_PROF]" . $>Willis</textarea> <input name="old[2][NOM_PROF]" type="hidden"  value="Willis"/></td><td> <textarea name="new[2][PRENOM_PROF]" . $>Bruce</textarea> <input name="old[2][PRENOM_PROF]" type="hidden"  value="Bruce"/></td><td> <textarea name="new[2][Email_Prof]" . $>BWillis@gmail.com</textarea> <input name="old[2][Email_Prof]" type="hidden"  value="BWillis@gmail.com"/></td></tr><input type="submi
    Vous l'aurez remarqué, il faut créer avec chaque zone de texte un text area invisible, et donner un nom à la text visible area "new[2][NOM_PROF]"
    et à la text area invisible "old[2][PRENOM_PROF]"

    Il y'a plusieurs difficultés :

    1) Il faudrait commencer la numérotation [n] après le dernier, cela devrait se faire grâce à mysql_num_rows() - 1 (le nombre de ligne déjà présentes dans la table - 1 car on commence la numérotation à zéro)
    2) Donner un nom bien précis pour la text area visible et invisible.

    Pour ce qui est du nom j'ai fait ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    input.name = new[NombreLignes][NOM_PROF]" . $;
    Une grosse difficulté est de changer le nom [NOM_PROF] par une variable qui correspond au nom de la colonne dans laquelle on est actuellement.

    Voici le code que j'utilise pour créer mon formulaire :

    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
    echo '<form action="MettreAJour.php" method="post" name="frmSaisie" id="frmSaisie">';
     
     
    	echo '<tr>';
    	for($i=0;$i<mysql_num_fields($query);$i++)
    		{
    		echo '<th>'.mysql_field_name($query,$i).'</th>';
    		}
    	echo '</tr>';
     
    	$nligne = 0;
    	$nbColonnes = 0;
    	while($row = mysql_fetch_array($query,MYSQL_ASSOC)) 
    	{
     
    	echo '<tr>';
    	foreach($row as $NomCol => $Valeur)
    		{
    			   echo '<td> <textarea name="new[' . $nligne . '][' . $NomCol . ']" . $>'.$Valeur.'</textarea> <input name="old[' . $nligne . '][' . $NomCol . ']" type="hidden"  value="'.$Valeur.'"/></td>';	
    		}
    	$nligne++;
    				echo '</tr>';
    	}
    	echo '<input type="submit" name="Submit" value="Mettre la table à jour" />' ; 
     
    	echo '</p>';
    	echo '</form>';
    Connaissez-vous un site qui expliquerais tout cela où pourriez-vous me mettre sur une première piste ?

    Merci d'avance.

    beegees

  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 663
    Points
    66 663
    Billets dans le blog
    1
    Par défaut
    voir l'article que j'ai mis dans la FAQ "FORM DYNAMIQUE MAIS PAS QUE FORM" ...

  3. #3
    Membre éprouvé
    Avatar de beegees
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2004
    Messages
    3 610
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Enseignement

    Informations forums :
    Inscription : Mars 2004
    Messages : 3 610
    Points : 1 277
    Points
    1 277
    Par défaut
    Bonjour SpaceFrog,

    Merci beaucoup pour ta réponse.

    Je vais aller voir ton tuto dans la faq.

    Il y a quelque chose qui m'inquiète réellement, c'est que quand je crée un input en javascript et que je vais voir la source dans firefox, il n'apparaît pas dans le code source HTML.

    Est-ce normal ?

    Merci encore.

    beegees

  4. #4
    Rédacteur
    Avatar de bigboomshakala
    Homme Profil pro
    Consultant Web .NET
    Inscrit en
    Avril 2004
    Messages
    2 077
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Consultant Web .NET
    Secteur : Finance

    Informations forums :
    Inscription : Avril 2004
    Messages : 2 077
    Points : 2 757
    Points
    2 757
    Par défaut
    le code source c'est ce que tu as écrit, donc c'est normal

  5. #5
    Membre éprouvé
    Avatar de beegees
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2004
    Messages
    3 610
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Enseignement

    Informations forums :
    Inscription : Mars 2004
    Messages : 3 610
    Points : 1 277
    Points
    1 277
    Par défaut
    Citation Envoyé par bigboomshakala Voir le message
    le code source c'est ce que tu as écrit, donc c'est normal
    Merci.

    Il n'y a donc aucun moyen ?

    Merci encore.

    beegees

  6. #6
    Rédacteur
    Avatar de bigboomshakala
    Homme Profil pro
    Consultant Web .NET
    Inscrit en
    Avril 2004
    Messages
    2 077
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Consultant Web .NET
    Secteur : Finance

    Informations forums :
    Inscription : Avril 2004
    Messages : 2 077
    Points : 2 757
    Points
    2 757
    Par défaut
    avec n'importe quel DOM inspector (installé de base sur FF) tu peux trouver des plug-in pour ton navigateur

  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 663
    Points
    66 663
    Billets dans le blog
    1
    Par défaut
    Comme le dit BBS avec firefox par exemple et la devwewtoolbar tu peux visualiser le "code généré"

  8. #8
    Membre éprouvé
    Avatar de beegees
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2004
    Messages
    3 610
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Enseignement

    Informations forums :
    Inscription : Mars 2004
    Messages : 3 610
    Points : 1 277
    Points
    1 277
    Par défaut
    Citation Envoyé par bigboomshakala Voir le message
    avec n'importe quel DOM inspector (installé de base sur FF) tu peux trouver des plug-in pour ton navigateur
    Citation Envoyé par SpaceFrog Voir le message
    Comme le dit BBS avec firefox par exemple et la devwewtoolbar tu peux visualiser le "code généré"
    Merci à vous deux pour vos réponses.

    Cela n'est-il pas possible avec AJAX ?

    Je ne peux pas demander à chaque visiteur d'installer le plug in firefox.

    Merci encore.

    beegees

  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 663
    Points
    66 663
    Billets dans le blog
    1
    Par défaut
    Heu c'est juste pour visualiser la source ...
    tu veux que les clients visualisent la source ????

Discussions similaires

  1. AutoCompleteExtender de zones de texte créées dynamiquement
    Par zakarinalaw dans le forum Développement Web avec .NET
    Réponses: 2
    Dernier message: 02/08/2013, 17h24
  2. Position de mes zones de texte sur ma page
    Par Greg12345 dans le forum Mise en page CSS
    Réponses: 4
    Dernier message: 18/07/2012, 14h55
  3. Réponses: 1
    Dernier message: 12/01/2010, 12h33
  4. [DOM] Element parent d'une div créée dynamiquement
    Par Général03 dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 16/03/2009, 21h26
  5. Réponses: 5
    Dernier message: 12/07/2004, 21h00

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