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

PHP & Base de données Discussion :

fonction duplication ligne(ajax) +php mysql


Sujet :

PHP & Base de données

  1. #1
    Membre confirmé
    Étudiant
    Inscrit en
    Mars 2009
    Messages
    108
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2009
    Messages : 108
    Par défaut fonction duplication ligne(ajax) +php mysql
    salut tout le monde voici une fonction que j'utilisais pour dupliquer des lignes à mon tableau
    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
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    <table id="table" width="905" border="1">
        <tr>
          <th width="108" scope="col"><div align="center">NATURE</div></th>
          <th width="155" scope="col">D.DEB.TRAV</th>
          <th width="155" scope="col">H.DEB.TRAV</th>
          <th width="155" scope="col">D.FIN.TRAV</th>
          <th width="155" scope="col">H.FIN.TRAV</th>
          <th width="137" scope="col">NOM EMPLOY&eacute; </th>
        </tr>
        <tr>
          <td rowspan="7">
            <label></label>
            COUPE</td>
     
          <? echo "<script language=\"javascript\">
    j=0;
      maxnbligne=6;
    	function AddRow(){
    	j++;
    	// Titre
    	  if (j<=maxnbligne){
    	var newRow = document.getElementById('table').insertRow(-1);
    	//
    	//
    	var newCell = newRow.insertCell(0);
    	newCell.align = 'center';
    	newCell.innerHTML = '<input type=\"text\" name=\"coul-aut-mat-pre['+j+']\" id=\"coul-aut-mat-pre['+j+']\" >';
    	//
    	var newCell = newRow.insertCell(1);
    	newCell.align = 'center';
    	newCell.innerHTML = '<input type=\"text\" name=\"coul-aut-mat-pre['+j+']\" id=\"coul-aut-mat-pre['+j+']\" >';
    	
    	//
    	var newCell = newRow.insertCell(2);
    	newCell.align = 'center';
    	newCell.innerHTML = '<input type=\"text\" name=\"coul-aut-mat-pre['+j+']\" id=\"coul-aut-mat-pre['+j+']\" >';
    	//
    	var newCell = newRow.insertCell(3);
    	newCell.align = 'center';
    	newCell.innerHTML = '<input type=\"text\" name=\"qte_aut_mat_pre['+j+']\" id=\"qte_aut_mat_pre['+j+']\" >';
    		//
    	var newCell = newRow.insertCell(4);
    	newCell.align = 'center';
    	newCell.innerHTML = '<select name=\"nom_emp_ass\" id=\"nom_emp_ass\" >";
    					include("dynamique/connect.php");
    				$requeteSelection="SELECT CONCAT(nom_emp,' ',pre_emp) FROM employe";
    				$resSelection=mysql_query($requeteSelection) or die (mysql_error());
    				while ($ligne=mysql_fetch_array($resSelection)){
        $valeur=$ligne[0];
        echo "<option value='".$valeur."'> $valeur </option>";
    }
    echo "</select>';
    		//
    	var newCell = newRow.insertCell(5);
    	newCell.align = 'center';
    	newCell.innerHTML = '<input name=\"clic\" type=\"button\" onClick=\"AddRow()\" value=\"ajouter ligne\">';
    	//
    	var newCell = newRow.insertCell(6);
    	newCell.align = 'center';
    	newCell.innerHTML = '<input type=\"button\" onclick=\"deleteCurrentRow(this)\" value=\"Supprimer\" alt=\"Delete\" >';
    }
    }
    function deleteCurrentRow(obj)
    {
    	var delRow = obj.parentNode.parentNode;
    	var tbl = delRow.parentNode;
    	
    	if(tbl.getElementsByTagName('tr').length==1){
    		alert('Vous ne pouvez pas supprimer cette ligne');return false ;
    	}
    	tbl.removeChild(delRow);
    }
    AddRow();
    
    </script>" ; ?>
    en effet le script marche à merveille mais dés que j'ai ajouter du code php en milieu tout s'est arrêté!! la fonction devient non fonctionel
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    newCell.innerHTML = '<select name=\"nom_emp_ass\" id=\"nom_emp_ass\" >";
    					include("dynamique/connect.php");
    				$requeteSelection="SELECT CONCAT(nom_emp,' ',pre_emp) FROM employe";
    				$resSelection=mysql_query($requeteSelection) or die (mysql_error());
    				while ($ligne=mysql_fetch_array($resSelection)){
        $valeur=$ligne[0];
        echo "<option value='".$valeur."'> $valeur </option>";
    }
    echo "</select>';
    avez vous une idée?

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Est-ce que tu as des erreurs javascript ?
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre confirmé
    Étudiant
    Inscrit en
    Mars 2009
    Messages
    108
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2009
    Messages : 108
    Par défaut
    Citation Envoyé par sabotage Voir le message
    Est-ce que tu as des erreurs javascript ?
    non aucun!! aucun message d'erreur n'apparait et la seule chose qui change c'est que au lieu des champs de la ligne du tableau, un vide apparait et ceci avec l'ajout du 2 code!!

    est ce que vous pensez que c'est le javascript qui est la source du problème!!

  4. #4
    Membre confirmé
    Inscrit en
    Avril 2009
    Messages
    37
    Détails du profil
    Informations forums :
    Inscription : Avril 2009
    Messages : 37
    Par défaut
    J'ai pas compris exactement ce que tu voulais faire mais bon...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    '<select name=\"nom_emp_ass\" id=\"nom_emp_ass\" >";
    					include("dynamique/connect.php");
    				$requeteSelection="SELECT CONCAT(nom_emp,' ',pre_emp) FROM employe";
    				$resSelection=mysql_query($requeteSelection) or die (mysql_error());
    				while ($ligne=mysql_fetch_array($resSelection)){
        $valeur=$ligne[0];
        echo "<option value='".$valeur."'> $valeur </option>";
    }
    echo "</select>';
    Il faut choisir si tu commences une chaine par ' elle doit se terminer par ', si tu l'as commence par " elle doit se terminer par "
    Ta chaine de caractere s'arrete dans ton SELECT... quand elle trouve la premiere ' ... et ca me surprend pas que cela ne marche pas.

    D'ailleurs tu n'as pas une erreur d'execution?

  5. #5
    Membre confirmé
    Étudiant
    Inscrit en
    Mars 2009
    Messages
    108
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2009
    Messages : 108
    Par défaut
    Citation Envoyé par garrath Voir le message
    J'ai pas compris exactement ce que tu voulais faire mais bon...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    '<select name=\"nom_emp_ass\" id=\"nom_emp_ass\" >";
    					include("dynamique/connect.php");
    				$requeteSelection="SELECT CONCAT(nom_emp,' ',pre_emp) FROM employe";
    				$resSelection=mysql_query($requeteSelection) or die (mysql_error());
    				while ($ligne=mysql_fetch_array($resSelection)){
        $valeur=$ligne[0];
        echo "<option value='".$valeur."'> $valeur </option>";
    }
    echo "</select>';
    Il faut choisir si tu commences une chaine par ' elle doit se terminer par ', si tu l'as commence par " elle doit se terminer par "
    Ta chaine de caractere s'arrete dans ton SELECT... quand elle trouve la premiere ' ... et ca me surprend pas que cela ne marche pas.

    D'ailleurs tu n'as pas une erreur d'execution?
    non aucune erreur
    je crois que tout simplement l'erreur c'est que du php dans du ajax ça ne marchera pas c'est tout....

  6. #6
    Membre éprouvé
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    97
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2008
    Messages : 97
    Par défaut
    Pourquoi utilise tu du javascript ? J'ai l'impression que ce que tu veux faire peut se faire a 100% en PHP....

    Je sais que ton code te semble evident mais pourais-tu expliquer ce que tu voulais faire ? J'ai l'impression que tu melanges peut-etre certains concept, et que tu veux faire quelque chose de plus simple que ce que ton code ne laisse a penser.

  7. #7
    Membre confirmé
    Inscrit en
    Avril 2009
    Messages
    37
    Détails du profil
    Informations forums :
    Inscription : Avril 2009
    Messages : 37
    Par défaut
    Citation Envoyé par roy-mustang Voir le message
    non aucune erreur
    je crois que tout simplement l'erreur c'est que du php dans du ajax ça ne marchera pas c'est tout....
    Ah OK Je vois mieux ce que tu fais...
    A priori effectivement pas de pb de ' ou "...

    Tu ne mets pas non plus de PHP dans du Ajax. Tu generes du html enfin du javascript a partir du php c pas pareil ...

    Allons-y pas a pas pour voir d'ou vient l'erreur...
    Essayes de mettre directement ce que tu veux generer en php en texte dans ton innerHTML . C-a-d constitue reellement ta chaine avec 2 3 lignes comme tu le veux :
    <option value='toto titi'>toto titi</option>
    <option value='tintin milou'>tintin milou</option>
    Tu le mets une premiere fois dans ta chaine (la toute grande)

    Tu essayes ensuite en rajoutant 2 echo
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    echo "<option value='toto titi'>toto titi</option>";
    echo "<option value='tintin milou'>tintin milou</option>";
    Si cela marche toujours c que tu as un probleme dans la partie code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    	include("dynamique/connect.php");
    				$requeteSelection="SELECT CONCAT(nom_emp,' ',pre_emp) FROM employe";
    				$resSelection=mysql_query($requeteSelection) or die (mysql_error());
    				while ($ligne=mysql_fetch_array($resSelection)){
        $valeur=$ligne[0];
        echo "<option value='".$valeur."'> $valeur </option>";
    }
    Dans ce code, je vois pas d'erreur. Essayes ce code de facon unitaire. Est ce que ta requete ramene bien des lignes ? etc...

Discussions similaires

  1. [PHP-JS] Auto-complétion [Ajax,PHP & MySQL]
    Par xdiethank dans le forum Langage
    Réponses: 4
    Dernier message: 21/07/2006, 15h18

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