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�cup�rer la valeur d'une cellule


Sujet :

JavaScript

Vue hybride

Message pr�c�dent Message pr�c�dent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Novembre 2009
    Messages
    15
    D�tails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 15
    Par d�faut r�cup�rer la valeur d'une cellule
    Bonjour,

    J'ai un souci avec l'utilisation des tables Html/Javascript. En fait, j'ai 3 listes li�es entre elles , lorsque je fais mon choix je clique sur un button Add pour le valider puis un row s'ajoute dans ma page Web et un champs de text "Prix " s'incr�mente avec les valeurs des articles !!maintenant j'ai fais une fonction remove pour supprimer le row , le probl�me c'est m�me je donne des Id au l'�l�ment , il y aura un d�calage si on supprime plusieurs rows !!

    Quelqu'un aurait une piste pour r�soudre cette histoire?
    voila les fonctions Add et Remove
    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
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    function addRow(tableID) {
                    var table = document.getElementById(tableID);
                    var rowCount = table.rows.length;
                    var row = table.insertRow(rowCount);
                    var cell1 = row.insertCell(0);
                    var element1 = document.createElement("input");
                    element1.type = "checkbox";
                    cell1.appendChild(element1);
                    var cell2 = row.insertCell(1);
                    cell2.innerHTML = rowCount + 1;
     
                    var cell3 = row.insertCell(2);
                    var element2 = document.createElement("input");
                    element2.type = "text";
                    element2.value=document.getElementById('audit').options[document.getElementById('audit').selectedIndex].text;;
     
                    cell3.appendChild(element2);
                    var cell4 = row.insertCell(3);
                    var element3 = document.createElement("input");
                    element3.type = "text";
                    element3.value=document.getElementById('finding2').options[document.getElementById('finding2').selectedIndex].text;
     
                    cell4.appendChild(element3);
                    var cell5 = row.insertCell(4);
                    var element4 = document.createElement("input");
                    element4.type = "text";
                    element4.value=document.getElementById('recommendation').options[document.getElementById('recommendation').selectedIndex].text;
     
                    cell5.appendChild(element4);
     
                    var cell6 = row.insertCell(5);
                    var element5 = document.createElement("input");
                    element5.type = "text";
     
                    element5.value=document.getElementById("calc_resultat").value*document.getElementById('prix_article').options[document.getElementById('prix_article').selectedIndex].text;
                    cell6.appendChild(element5);
     
                    Total();
     
     
     
                }
     
                function deleteRow(tableID) {
                    try {
                        var table = document.getElementById(tableID);
                        var rowCount = table.rows.length;
     
                        for(var i=0; i<rowCount; i++) {
                            var row = table.rows[i];
                            var chkbox = row.cells[0].childNodes[0];
                            if(null != chkbox && true == chkbox.checked) {
                                table.deleteRow(i);
                                rowCount--;
     
                                i--;
                            }
     
                        }
                    }catch(e) {
                        alert(e);
                    }
     
     
                }
    Merci d'avance !!

  2. #2
    Membre Expert
    Avatar de Loceka
    Profil pro
    Inscrit en
    Mars 2004
    Messages
    2 276
    D�tails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2004
    Messages : 2 276
    Par d�faut
    Dans ton code il n'y a aucun ID au contraire

    Mais sinon c'est pas compliqu� : quand tu supprimes une ligne il te suffit de recalculer tous les ids qui suivent cette ligne.

  3. #3
    Expert confirm�
    Avatar de sekaijin
    Homme Profil pro
    Urbaniste
    Inscrit en
    Juillet 2004
    Messages
    4 205
    D�tails du profil
    Informations personnelles :
    Sexe : Homme
    �ge : 61
    Localisation : France, Yvelines (�le de France)

    Informations professionnelles :
    Activit� : Urbaniste
    Secteur : Sant�

    Informations forums :
    Inscription : Juillet 2004
    Messages : 4 205
    Par d�faut
    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    3
    4
    5
    for(var i=0; i<rowCount; i++) {
        var row = table.rows[i];
        var chkbox = row.cells[0].childNodes[0];
        if(null != chkbox && true == chkbox.checked) {
            table.deleteRow(i);
    cela ne peut pas fonctionner
    car si tu enl�ve un row les indices se d�calent automatiquement
    il faut utiliser les membres du DOM
    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    var row = document.getElementById(tableID).tbody.firstChild;
    while (row) {
      var current = row;
      row = current .nextSibilin;
      var chkbox = current.cells[0].childNodes[0];
       if(null != chkbox && true == chkbox.checked) {
         document.getElementById(tableID).tbody.removeChild(current);
       }
    }
    A+JYT

  4. #4
    Membre averti
    Inscrit en
    Novembre 2009
    Messages
    15
    D�tails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 15
    Par d�faut
    il faut utiliser les membres du DOM
    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    var row = document.getElementById(tableID).tbody.firstChild;
    while (row) {
      var current = row;
      row = current .nextSibilin;
      var chkbox = current.cells[0].childNodes[0];
       if(null != chkbox && true == chkbox.checked) {
         document.getElementById(tableID).tbody.removeChild(current);
       }
    }
    oui , c'est �a le probl�me , sinon je dois ajouter un Id et red�finer la fonction delete ??!

  5. #5
    Membre averti
    Inscrit en
    Novembre 2009
    Messages
    15
    D�tails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 15
    Par d�faut
    oui ,j'ai supprim� L'Id ,element5.id=c++ mais je vois pas comment je peux red�finir les Id

Discussions similaires

  1. [JTable] R�cup�rer la valeur d'une cellule
    Par yosh� dans le forum Composants
    R�ponses: 9
    Dernier message: 28/06/2016, 05h56
  2. R�cup�rer la valeur d'une cellule du tableur OOo
    Par manubrard dans le forum API, COM et SDKs
    R�ponses: 7
    Dernier message: 22/02/2006, 17h51
  3. [WebForms][DataGrid] R�cup�rer la valeur d'une cellule...
    Par elbj dans le forum G�n�ral Dotnet
    R�ponses: 2
    Dernier message: 12/12/2005, 14h00
  4. [C#] [Automation Word] R�cup�rer la valeur d'une cellule
    Par Ditch dans le forum Windows Forms
    R�ponses: 2
    Dernier message: 16/06/2004, 15h57

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