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 :

Remplacer une cellule par une zone de texte dans un script existant


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 Remplacer une cellule par une zone de texte dans un script existant
    Salut tout le monde,

    J'ai un script javascript qui me permet d'ajouter une ligne (plusieurs lignes les unes en dessous des autres si je clics plusieurs fois sur le bouton).

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
     
    <?php
    $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);
    var newCell = newRow.insertCell(0);
    for(i = 0; i < NombreCellules; i++)
    {
    newCell.innerHTML = ' ';
    newCell = newRow.insertCell(1);
    newCell.innerHTML = ' ';
    }
    }
    </script>';
    J'obtiens bien ma ligne avec le nombre de cellules adéquate mais le problème est que j'obtiens des cellules non modifiables.

    J'aimerais obtenir à la place des zone de texte éditables.

    Sauriez-vous me dire comment je dois faire ?

    Merci d'avance pour votre aide.

    beegees

  2. #2
    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
    à la place du innerHTML

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    var input = document.createElement("input");
    input.type = "text";
    newCell.appendChild(input);

  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
    Citation Envoyé par bigboomshakala Voir le message
    à la place du innerHTML

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    var input = document.createElement("input");
    input.type = "text";
    newCell.appendChild(input);
    Merci beaucoup bigboomshakala,

    J'ai donc remplacé les deux innerHTML par ton code ce qui me donne ceci :

    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
    <script type="text/javascript">
    function AddRow(NombreCellules)
    {
    var newRow = document.getElementById('TableauUpdate').insertRow(-1); //on ajoute une ligne en fin de tableau
    var newCell = newRow.insertCell(0);
    for(i = 0; i < NombreCellules - 1; i++)
    {
    var input = document.createElement("input");
    input.type = "text";
    newCell.appendChild(input);
    newCell = newRow.insertCell(1);
    input.type = "text";
    newCell.appendChild(input);
     
     
    }
    }
    </script>';
    Comme ceci, il n'y a que trois zones de texte qui se construisent.

    La première ne se construit pas.

    Qu'en penses-tu ?

    Merci encore.

    begees

  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
    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 - 1; i++)
      {
        var input = document.createElement("input");
        input.type = "text";
        newCell = newRow.insertCell(i);
        newCell.appendChild(input);
      }
    }
    </script>

  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
    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 - 1; i++)
      {
        var input = document.createElement("input");
        input.type = "text";
        newCell = newRow.insertCell(i);
        newCell.appendChild(input);
      }
    }
    </script>
    Merci beaucoup bigboomshakala.

    Ce problème est résolu.

    Encore merci pour ton aide.

    beegees

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

Discussions similaires

  1. Remplacer le contenu d'une cellule par d'autres
    Par yezispam dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 14/04/2015, 15h05
  2. Réponses: 1
    Dernier message: 13/04/2015, 11h17
  3. remplacer le contenu d'une cellule par un autre avec une macro
    Par valentin31 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 08/11/2012, 09h02
  4. [XL-2002] Macro de comparaison d'une cellule d'une feuille avec une cellule d'une autre feuille.
    Par steelydan dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 08/09/2010, 12h59
  5. [XL-2007] [FORM] remplacer la valeur d'une cellule par une autre
    Par coldavires dans le forum Excel
    Réponses: 7
    Dernier message: 21/01/2010, 22h34

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