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

jQuery Discussion :

Contenu javascript sur une page ajax


Sujet :

jQuery

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Juin 2011
    Messages
    41
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations forums :
    Inscription : Juin 2011
    Messages : 41
    Points : 29
    Points
    29
    Par défaut Contenu javascript sur une page ajax
    Bonjour,

    J'utilise actuellement ajax depuis relativement peu de temps et je suis confronté à un problème.

    Sur ma page requete.php, qui est celle qui va afficher le contenu récupéré par AJAX, j'ai le script tout simple

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    <script type="text/javascript">
    var name = "test";
    alert(name);
    </script>
    Au chargement de la page AJAX, je reçois l'alerte.

    Maintenant, avec ce code là :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    <script type="text/javascript">
    var name = "test";
    <a href="#" onclick="alert(name);">test</a>
    </script>
    Je reçois une alerte à contenu vide quand je clique sur le lien.


    J'en déduis donc que lors d'une requête AJAX, le javascript est exécuté mais toutes les données sont ensuite immédiatement supprimées.

    Est-ce vrai ? Si non, que se passe-t'il ? Si oui, comment faire pour contourner le problème ?

    Merci d'avance de votre aide,

    7804j

  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 665
    Points
    66 665
    Billets dans le blog
    1
    Par défaut
    sujet maintes fois traité...
    une recherche s'impose ...

    sinon y'a des articles comme celui ci
    http://dmouronval.developpez.com/tut...-requete-ajax/

  3. #3
    Membre éclairé Avatar de micetf
    Homme Profil pro
    Professeur des Ecoles
    Inscrit en
    Mai 2009
    Messages
    557
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ardèche (Rhône Alpes)

    Informations professionnelles :
    Activité : Professeur des Ecoles
    Secteur : Enseignement

    Informations forums :
    Inscription : Mai 2009
    Messages : 557
    Points : 831
    Points
    831
    Par défaut
    Bonjour,

    Malgré la réponse de SpaceFrog, je pense que la réponse n'est pas aussi complexe :
    Je penche plutôt pour le fait que 'name' soit un mot réservé en JS.
    En effet, essaye avec 'nom' au lieu de 'name' et là tu n'auras plus de soucis.

    Code PHP : 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
     
    <html>
    <head>
    <script type="text/javascript" src="js/jquery-1.5.1.min.js"></script>
    <script type="text/javascript">
    $(document).ready(function() {
    	$('input').click(function() {
    		$.post('requete.php',function(data){
    			$('#data').html(data);
    		});
    	});
    });
    </script>
    </head>
    <body>
    <input type="button" value="test"/>
    <div id="data"></div>
    </body>
    </html>
    et
    Code PHP : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    <?php 
    echo '
    <script type="text/javascript">
    var nom="autre";
    </script>
    <a href="#" onclick="alert(nom); return false;">test</a>
    ';

    Mais peut-être me trompe-je...

    MiCetF

  4. #4
    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 665
    Points
    66 665
    Billets dans le blog
    1
    Par défaut
    j'ai cru comprendre que la question portait sur l'interprétation du javascript contenu dans une reponse Ajax ?

    Les echanges entre client et serveur ne se font que sous format de string ...
    Si un script est contenu dans la réponse il ne sera pas interprété.

    Mais il est clair que nommer une variable name, c'est tendre le baton pour se faire battre ...

  5. #5
    Membre éclairé Avatar de micetf
    Homme Profil pro
    Professeur des Ecoles
    Inscrit en
    Mai 2009
    Messages
    557
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ardèche (Rhône Alpes)

    Informations professionnelles :
    Activité : Professeur des Ecoles
    Secteur : Enseignement

    Informations forums :
    Inscription : Mai 2009
    Messages : 557
    Points : 831
    Points
    831
    Par défaut
    Citation Envoyé par SpaceFrog Voir le message
    Les echanges entre client et serveur ne se font que sous format de string ...
    Si un script est contenu dans la réponse il ne sera pas interprété.
    Ce serait le cas si la réponse ajax était traitée comme telle (string) :
    mais jquery permet de passer par le DOM et, finalement, cela se fait très facilement :
    MiCetF

  6. #6
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    <script type="text/javascript">
    var name = "test";
    <a href="#" onclick="alert(name);">test</a>
    </script>
    Ben surtout, on ne peut pas intégrer du HTML dans un script
    Ensuite, pour le choix de name comme nom de variable... c'est effectivement avoir envie de souffrir !

  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 665
    Points
    66 665
    Billets dans le blog
    1
    Par défaut

    en effet je confonds avec XMLHTTPRequest tout court sans jquery
    Jquery permet en effet avec html() d'interpréter les scripts en retour ...

  8. #8
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Juin 2011
    Messages
    41
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations forums :
    Inscription : Juin 2011
    Messages : 41
    Points : 29
    Points
    29
    Par défaut
    ERF ! C'était effectivement le nom de la variable...

    Je crois que je vais arrêter de faire mon Englych bicose je fais tout buguer.

    Merci de l'aide

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

Discussions similaires

  1. Effets hover sur une page ajax
    Par sub_zero dans le forum Général JavaScript
    Réponses: 7
    Dernier message: 06/06/2015, 22h15
  2. [XL-2010] Executer un javascript sur une page web
    Par Seka007 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 20/06/2013, 15h33
  3. désactiver un javascript sur une page
    Par Giantrick dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 28/11/2007, 09h11
  4. [Debutant] Mettre 2 javascript sur une page
    Par hugo69 dans le forum Général JavaScript
    Réponses: 8
    Dernier message: 06/07/2006, 12h26
  5. javascript sur une page creation flash mx
    Par hadjplasma dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 17/08/2005, 12h06

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