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 :

page mère/page fille : exécuter du code js dans la page fille


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 493
    Billets dans le blog
    1
    Par défaut page mère/page fille : exécuter du code js dans la page fille
    Bonjour,

    ceci est en fait la suite de ce fil, mais j'en fais un nouveau car 1) le titre ne convient plus et 2) j'avais coché le précédent comme "résolu".
    Ce que je voudrais faire, c'est en fonction de l'action faite dans la page mère, exécuter une certaine fonction js dans la page fille. Or si je mets du code html dans la page fille, ça marche bien, mais si j'y mets du code js, au lieu de l'exécuter, ça affiche le code. Donc je recherche une solution.
    Le code qui marche (html dans la page fille) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    <script>
    function pagefille() {
    document.getElementById("idDiv").innerHTML = "coucou";
    }
     
    document.write('<div id="idDivParent">');
     
    setTimeout(pagefille,1000);
     
    document.write('</div><div id="idDiv"></div>');
    </script>
    Le code qui échoue (js dans la page fille) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    <script>
    function pagefille() {
    document.getElementById("idDiv").innerHTML = "<script>document.write('coucou');</script>";
    }
     
    document.write('<div id="idDivParent">');
     
    setTimeout(pagefille,1000);
     
    document.write('</div><div id="idDiv"></div>');
    </script>
    Comment puis-je faire ?

  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 659
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    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 659
    Billets dans le blog
    1
    Par défaut
    déja document.write ...

    ensuite
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     "<script>document.write('coucou');</script>";

    compris comme balise de fermeture de ton script
    =>
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     "<script>document.write('coucou');</s" +"cript>";
    }
    mais il est préférable de passer par le DOM ...
    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 !

  3. #3
    Membre Expert Avatar de Willpower
    Homme Profil pro
    sans emploi
    Inscrit en
    Décembre 2010
    Messages
    1 009
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : sans emploi

    Informations forums :
    Inscription : Décembre 2010
    Messages : 1 009
    Par défaut
    document.getElementById("idDiv").innerHTML = "<script>document.write('coucou');</script>";
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    var s = document.createElement('script');
    s.type = "text/javascript";
    if(!!s.textContent)
      s.textContent = "document.write('coucou');";
    else
      s.innerText  = "document.write('coucou');";
    document.getElementById("idDiv").innerHTML = ""; // pour vider le div
    document.getElementById("idDiv").appendChild(s);

  4. #4
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 493
    Billets dans le blog
    1
    Par défaut
    Merci pour les réponses ; du coup, j'ai essayé ça :
    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
    <script>
    function pagefille() {
    var s = document.createElement('script');
    s.type = "text/javascript";
    if(!s.textContent)
      s.textContent = "document.write('coucou');";
    else 
      s.innerText  = "document.write('coucou');";
    document.getElementById("idDiv").innerHTML = ""; // pour vider le div
    document.getElementById("idDiv").appendChild(s);}
     
    document.write('<div id="idDivParent">');
     
    setTimeout(pagefille,1000);
     
    document.write('</div><div id="idDiv"></div>');
    </script>
    mais il ne se passe rien...(page blanche)

    et j'ai aussi essayé ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    <script>
    function pagefille() {
     document.getElementById("idDiv").innerHTML ="<script>document.write('coucou');</s" +"cript>";
    }
     
    document.write('<div id="idDivParent">');
     
    setTimeout(pagefille,1000);
     
    document.write('</div><div id="idDiv"></div>');
    </script>
    Pas mieux...

  5. #5
    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 659
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    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 659
    Billets dans le blog
    1
    Par défaut
    c'est pas très clair tout ça
    il faudrait préciser sur quelle page se trouve le script et depusi quelle page tu essaye de le lancer ..
    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 !

  6. #6
    Membre Expert Avatar de Willpower
    Homme Profil pro
    sans emploi
    Inscrit en
    Décembre 2010
    Messages
    1 009
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : sans emploi

    Informations forums :
    Inscription : Décembre 2010
    Messages : 1 009
    Par défaut
    au temps, pour moi, je ne l'avais pas testé ! voici la bonne version :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    var script = document.createElement('script');
    script.text= "document.write('coucou');";
    document.getElementById("idDiv").innerHTML = ""; // pour vider le div
    document.getElementById("idDiv").appendChild(script);

  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 659
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    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 659
    Billets dans le blog
    1
    Par défaut
    répandu ... avec un A will
    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 !

  8. #8
    Membre Expert Avatar de Willpower
    Homme Profil pro
    sans emploi
    Inscrit en
    Décembre 2010
    Messages
    1 009
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : sans emploi

    Informations forums :
    Inscription : Décembre 2010
    Messages : 1 009
    Par défaut
    Citation Envoyé par SpaceFrog Voir le message
    répandu ... avec un A will

  9. #9
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 493
    Billets dans le blog
    1
    Par défaut
    voici la bonne version
    Ca marche chez toi ? Pas chez moi.
    et voici mon code (pour plus de clarté, j'ai renommé le div "fille") :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    <script>
    function pagefille() {
    var script = document.createElement('script');
    script.text= "document.write('coucou');";
    document.getElementById("idDivfille").innerHTML = ""; // pour vider le div
    document.getElementById("idDivfille").appendChild(script);
    }
     
    document.write('<div id="idDivParent">');
     
    setTimeout(pagefille,1000);
     
    document.write('</div><div id="idDivfille"></div>');
    </script>

    Et il fait quoi ce script imbittable le plus répandu ?

  10. #10
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 493
    Billets dans le blog
    1
    Par défaut
    L'idée globale est de demander à l'utilisateur de faire un choix côté page mère, et en fonction de ce choix de lancer la fonction js correspondante côté fille, d'où la nécessité d'exécuter du js côté fille.

  11. #11
    Membre Expert Avatar de Willpower
    Homme Profil pro
    sans emploi
    Inscrit en
    Décembre 2010
    Messages
    1 009
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : sans emploi

    Informations forums :
    Inscription : Décembre 2010
    Messages : 1 009
    Par défaut
    Citation Envoyé par laurentSc Voir le message
    Ca marche chez toi ? Pas chez moi.
    et voici mon code (pour plus de clarté, j'ai renommé le div "fille") :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    <script>
    function pagefille() {
    var script = document.createElement('script');
    script.text= "document.write('coucou');";
    document.getElementById("idDivfille").innerHTML = ""; // pour vider le div
    document.getElementById("idDivfille").appendChild(script);
    }
     
    document.write('<div id="idDivParent">');
     
    setTimeout(pagefille,1000);
     
    document.write('</div><div id="idDivfille"></div>');
    </script>
    je n'avais pas vu ton setTimeout, je n'avais pas bien regardé mais tu as créé le pire code JS que je n'ai jamais vu.

    en fait, ça ne fonctionne pas (sous IE) car avec ton timeout, la fonction s'éxecute après le chargement de la page (window.onload) et donc les document.write sont interdits. (mais si tu le remplace par un "alert('coucou');" par exemple, ça fonctionne).

    ensuite ça ne sert à rien de placer ton setTimeout entre la balise ouvrante et fermante d'un div.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    document.write('<div id="idDivParent">');
     
    setTimeout(pagefille,1000);
     
    document.write('</div><div id="idDivfille"></div>');
    puisque que le settimeout signifie que ton code sera exécuté plus tard.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    document.write('<div id="idDivParent"></div><div id="idDivfille"></div>');
    setTimeout(pagefille,1000);
    bien que je ne vois pas non plus l'intérêt du document.write plutôt que de l'écrire en html :

    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    <body>
    <div id="idDivParent"></div><div id="idDivfille">
    <script>
    setTimeout(pagefille,1000);
    </script>
    </body>

    enfin, si ton settimeout ne servait qu'a s'assurer que le div était deja créé, alors il suffit de placer le code après (ou dans window.onload mais surtout pas dans ce cas présent puisque ta fonction pagefille appelle document.write) :

    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    <body>
    <div id="idDivParent"></div><div id="idDivfille">
    <script>
    pagefille();
    </script>
    </body>

    là, c'est dejà beaucoup plus propre.

    Citation Envoyé par laurentSc Voir le message
    Et il fait quoi ce script imbittable le plus répandu ?
    ça n'a rien à voir avec le poste, c'est ma signature qui est là pour me rebeller contre les membres de ce forum qui critiquent le document.write à tout va ! (en fait si, ça a tout avoir avec ce sujet^^) alors que bien utilisé(càd lors de la création du dom, avant donc le window.onload), il a tout a fait sa place dans javascript.

    edit: le script en question, c'est google adsense.

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

Discussions similaires

  1. Exécution code C# dans une page ASP.NET
    Par anubis55 dans le forum C#
    Réponses: 11
    Dernier message: 06/06/2011, 21h16
  2. Intégré une zone de code HTML dans 1 page HTML sans Altéré le reste de la page
    Par sozik dans le forum Balisage (X)HTML et validation W3C
    Réponses: 1
    Dernier message: 08/04/2007, 10h38
  3. Réponses: 2
    Dernier message: 22/08/2006, 11h28
  4. Placement du code ASP dans la page WEB
    Par sam.fet dans le forum ASP
    Réponses: 2
    Dernier message: 11/08/2006, 17h12
  5. Inclure code XML dans une page HTML ?
    Par kpatoulu dans le forum XML/XSL et SOAP
    Réponses: 1
    Dernier message: 24/10/2005, 14h59

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