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 :

Modifier DOM et inclure du php


Sujet :

JavaScript

  1. #1
    Membre du Club
    Homme Profil pro
    Enseignant
    Inscrit en
    Janvier 2018
    Messages
    85
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2018
    Messages : 85
    Points : 40
    Points
    40
    Par défaut Modifier DOM et inclure du php
    Bonjour tout le forum, j'ai besoin de votre aide.

    Voici mon formulaire :
    Code html : 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
    <!DOCTYPE html>
    <html lang="fr">
    	<head>
    		<meta charset="UTF-8">
    		<meta http-equiv="X-UA-Compatible" content="IE=edge">
    		<meta name="viewport" content="width=device-width, initial-scale=1.0">
    		<title>Document</title>
    	</head>
    	<body>
    		<div id="pieces">
    			<div id="piece1">
    				Pièce 1 <?php include("/var/www/compte_rendu/liste_piece.php");?>
    				Prix <input type="number" name="prix1" id="prix1" />
    				Quantité <input type="number" name="quantite1" id="quantite1" />
    			</div>
    		</div>
    		<div id="ajouterPiece">
    			<input type="button" name="buttonAjouterPiece" id="buttonAjouterPiece" value="Rajouter une pièce" onClick="ajouterPiece(1)" />
    		</div>
    		<script type="text/javascript" src="/test.js"></script>
    	</body>
    </html>

    Je souhaite que l'utilisateur puisse ajouter des pièces avant l'envoi du formulaire, voici le JavaScript dans un fichier à part src="/test.js" :
    Code javascript : 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
    function ajouterPiece(numPiece) {
    	// console.log("Passage fonction ajouterPiece");
     
    	let nouvelleDiv = document.createElement("div");
     
    	let numPieceSuivante = numPiece + 1;
     
    	document
    		.getElementById("pieces")
    		.appendChild(nouvelleDiv)
    		.setAttribute("id", "piece" + numPieceSuivante);
     
    	const nouvellePiece = document.getElementById("piece" + numPieceSuivante);
    	nouvellePiece.innerHTML =
    	`Pièce ` + numPieceSuivante +`
    	<?php include("/var/www/compte_rendu/liste_piece.php");?>
    	Prix
    	<input type="number" name="prix` + numPieceSuivante + `" id="prix` + numPieceSuivante + `" />
    	Quantité
    	<input type="number" name="quantite` + numPieceSuivante + `" id="quantite` + numPieceSuivante + `" />`
     
    	document.getElementById('ajouterPiece').innerHTML = '<input type="button" name="buttonAjouterPiece" id="buttonAjouterPiece" value="Rajouter une pièce" onClick="ajouterPiece(' + numPieceSuivante + ')" />';
    }

    Mon problème, c'est le code php ligne 17, il est bien inclus, mais comme commentaire.



    J'arrive à obtenir le bon fonctionnement en incluant directement le JavaScript dans la page html du formulaire dans une balise <script>:
    Code html : 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
    <!DOCTYPE html>
    <html lang="fr">
    	<head>
    		<meta charset="UTF-8">
    		<meta http-equiv="X-UA-Compatible" content="IE=edge">
    		<meta name="viewport" content="width=device-width, initial-scale=1.0">
    		<title>Document</title>
    	</head>
    	<body>
    		<div id="pieces">
    			<div id="piece1">
    				Pièce 1 <span id="listePiece1"><?php include("/var/www/compte_rendu/liste_piece.php");?></span>
    				Prix <input type="number" name="prix1" id="prix1" />
    				Quantité <input type="number" name="quantite1" id="quantite1" />
    			</div>
    		</div>
    		<div id="ajouterPiece">
    			<input type="button" name="buttonAjouterPiece" id="buttonAjouterPiece" value="Rajouter une pièce" onClick="ajouterPiece(1)" />
    		</div>
    		<script>
                            function ajouterPiece(numPiece) {
                                    // console.log("Passage fonction ajouterPiece");
     
                                    let nouvelleDiv = document.createElement("div");
     
                                    let numPieceSuivante = numPiece + 1;
     
                                    document
                                            .getElementById("pieces")
                                            .appendChild(nouvelleDiv)
                                            .setAttribute("id", "piece" + numPieceSuivante);
     
                                    const nouvellePiece = document.getElementById("piece" + numPieceSuivante);
                                    nouvellePiece.innerHTML =
                                    `Pièce ` + numPieceSuivante +`
                                    <span id="listePiece` + numPieceSuivante +`"></span>
                                    Prix
                                    <input type="number" name="prix` + numPieceSuivante + `" id="prix` + numPieceSuivante + `" />
                                    Quantité
                                    <input type="number" name="quantite` + numPieceSuivante + `" id="quantite` + numPieceSuivante + `" />`
     
                                    let codePhp = `<?php include("/var/www/compte_rendu/liste_piece.php");?>`;
                                    document
                                            .getElementById("listePiece" + numPieceSuivante)
                                            .innerHTML = codePhp;
     
                                    document.getElementById('ajouterPiece').innerHTML = '<input type="button" name="buttonAjouterPiece" id="buttonAjouterPiece" value="Rajouter une pièce" onClick="ajouterPiece(' + numPieceSuivante + ')" />';
                            }
                    </script>
    	</body>
    </html>

    Comment obtenir le même fonctionnement avec un fichier à part ?

    Merci pour votre aide.

  2. #2
    Expert éminent sénior
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 234
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 234
    Points : 15 531
    Points
    15 531
    Par défaut
    j'ai l'impression que vous vous emmêler les pinceaux dans l'ordre d'exécution de php et javascript. regarde le schéma de cette page qui donne plus de détails à ce sujet :
    https://dmouronval.developpez.com/tu...te-ajax/#Lno-I

  3. #3
    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 637
    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 637
    Points : 66 658
    Points
    66 658
    Billets dans le blog
    1
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

  4. #4
    Membre du Club
    Homme Profil pro
    Enseignant
    Inscrit en
    Janvier 2018
    Messages
    85
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2018
    Messages : 85
    Points : 40
    Points
    40
    Par défaut
    Bonjour, merci pour vos réponses.

    J'ai coupé le code en deux. Une partie dans un fichier dédié qui modifie le html, une partie dans le fichier html, dans une balise <script> qui inclut le code php

    Code html : 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
    <!DOCTYPE html>
    <html lang="fr">
    	<head>
    		<meta charset="UTF-8">
    		<meta http-equiv="X-UA-Compatible" content="IE=edge">
    		<meta name="viewport" content="width=device-width, initial-scale=1.0">
    		<title>Document</title>
    	</head>
    	<body>
    		<div id="pieces">
    			<div id="piece1">
    				Pièce 1 <span id="listePiece1"><?php include("/var/www/compte_rendu/liste_piece.php");?></span>
    				Prix <input type="number" name="prix1" id="prix1" />
    				Quantité <input type="number" name="quantite1" id="quantite1" />
    			</div>
    		</div>
    		<div id="ajouterPiece">
    			<input type="button" name="buttonAjouterPiece" id="buttonAjouterPiece" value="Rajouter une pièce" onClick="ajouterPiece(1); includeListePieces(1)" />
    		</div>
    		<script type="text/javascript" src="/test2.js"></script>
    		<script>
                            function includeListePieces(numPiece){
     
                                    let numPieceSuivante = numPiece + 1;
     
                                    let codePhp = `<?php include("/var/www/compte_rendu/liste_piece.php");?>`;
                                    document
                                            .getElementById("listePiece" + numPieceSuivante)
                                            .innerHTML = codePhp;
                            }
                    </script>
    	</body>
    </html>

    Code javascript : 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
    function ajouterPiece(numPiece) {
    	// console.log("Passage fonction ajouterPiece");
     
    	let nouvelleDiv = document.createElement("div");
     
    	let numPieceSuivante = numPiece + 1;
     
    	document
    		.getElementById("pieces")
    		.appendChild(nouvelleDiv)
    		.setAttribute("id", "piece" + numPieceSuivante);
     
    	const nouvellePiece = document.getElementById("piece" + numPieceSuivante);
    	nouvellePiece.innerHTML =
    	`Pièce ` + numPieceSuivante +`
    	<span id="listePiece` + numPieceSuivante +`"></span>
    	Prix
    	<input type="number" name="prix` + numPieceSuivante + `" id="prix` + numPieceSuivante + `" />
    	Quantité
    	<input type="number" name="quantite` + numPieceSuivante + `" id="quantite` + numPieceSuivante + `" />`
     
    	document.getElementById('ajouterPiece').innerHTML = '<input type="button" name="buttonAjouterPiece" id="buttonAjouterPiece" value="Rajouter une pièce" onClick="ajouterPiece(' + numPieceSuivante + '); listePiece(' + numPieceSuivante + ')" />';
    }

Discussions similaires

  1. inclure du php dans un <td>
    Par pierrot10 dans le forum Langage
    Réponses: 11
    Dernier message: 21/03/2006, 14h44
  2. [DOM] Validation xml avec PHP
    Par thefaycal dans le forum Bibliothèques et frameworks
    Réponses: 6
    Dernier message: 26/01/2006, 21h15
  3. [DOM] Parsage XML en PHP 4
    Par Huntress dans le forum Bibliothèques et frameworks
    Réponses: 7
    Dernier message: 07/12/2005, 22h24
  4. [DOM XML] XMLDOM et PHP
    Par trent94 dans le forum Bibliothèques et frameworks
    Réponses: 4
    Dernier message: 03/10/2005, 11h44
  5. [DOM XML] XML -> tableau PHP
    Par Mucsy dans le forum Bibliothèques et frameworks
    Réponses: 6
    Dernier message: 03/06/2005, 11h44

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