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 :

onclick declaré depuis une iframe disparait si on recharge l'iframe


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Février 2007
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 12
    Par défaut onclick declaré depuis une iframe disparait si on recharge l'iframe
    Hello,

    Description de la page :
    J'ai une page avec un formulaire pour envoyer une image, et une liste d'image qui s'affiche sous ce formulaire (les images que j'ai chargé avec le formulaire). A coté de chaque image j'ai un lien "Supprimer" pour retirer une image de cette liste.

    Mon procédé
    J'utilise une iframe comme cible de ce formulaire.

    Dans l'iframe, je traite en PHP l'image reçue. Et j'utilise ensuite Javascript pour afficher l'image nouvellement uploadée sur ma page. Toujours en JS, j'ajoute un lien permettant de supprimer cette image.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    var a = top.document.createElement('a');
    a.href = '#void';
    a.onclick = function () { alert('ok'); }
    alert(a.getAttribute('onclick'));
    li.appendChild(a);
    Mon problème :
    Si j'ajoute une seule image, ça marche bien ; mon image s'affiche et le lien "Supprimer" s'ajoute et fonctionne.
    Mais si j'ajoute 2 images à la suite, je perds le onclick du 1er lien crée (le 2e fonctionne).

    Si j'ai bien compris, c'est parce que mon code ci-dessus fait que je déclare ma fonction dans mon iframe. Donc quand celle-ci est rechargée à nouveau, je perds ma fonction, et mon onclick.

    J'ai essayé de modifier directement l'attribut HTML onclick du lien :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    a.setAttribute('onclick', \"javascript:alert('ok');\");
    Mais malgré un :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    a.getAttribute('onclick');
    qui affiche le bon résultat, mon onclick ne fonctionne pas (sous IE).



    Quelqu'un a-t-il une idée de comment modifier le onclick, ou comment faire pour qu'il persiste dans ma fenetre principale malgré un rechargement de l'iframe?

  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
    mettre la fonction dans le top ? ou declarer une variable dans le top

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    var top.document.a = top.document.createElement('a');
    top.document.a.href = '#void';
    top.document.a.onclick = function () { alert('ok'); }
    alert(top.document.a.getAttribute('onclick'));
    ...
    // mais le li il se trouve ou ???
    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 habitué
    Profil pro
    Inscrit en
    Février 2007
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 12
    Par défaut
    J'ai joint une petite explication visuelle.

    J'ai bien essayé de mettre la fonction dans le top en faisant un :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    a.onclick = top.function () { alert('ok'); }
    Mais visiblement ce n'est pas la bonne synthaxe.
    Mais je pense que c'est la piste à suivre.

    Mon "var a" ne me sert que de variable temporaire. Je ne le réutilise pas après donc je pense que "top.document.a" ne me sert pas.

    C'est vraiment la partie "function () {}" que je perds dans cette histoire.

    Je viens de tester ça sans succès (le $i est dans un for () qui va de 0 à 10 pour identifier mes images) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    top.document.func_annonceFormImageLien".$i." = function () { [...] }
    a.onclick = top.document.func_annonceFormImageLien".$i.";
    Images attachées Images attachées  

  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 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
    Mon "var a" ne me sert que de variable temporaire. Je ne le réutilise pas après donc je pense que "top.document.a" ne me sert pas.
    ben si tu es dans l'iframe ... a est affectée à window ... donc au frame ... tu fermes le frame = tu perds a ...
    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 !

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Février 2007
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 12
    Par défaut
    Si je comprends bien, on peut penser que je garde le ID, HREF et tout parce que ce sont des attributs HTML mais que mon onclick est une propriété javascript et non un attribut HTML, et que donc ce serait perdu si je perds "a".

    Malheureusement mettre top.document.a ne semble pas résoudre mon problème.

    Je vais voir si je peux "simplifier" le système dans une page vierge à part et la mettre en piece jointe

  6. #6
    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
    le li dans lequel tu appendes ... ilo est dans l'iframe ou dans le top ?
    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 !

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

Discussions similaires

  1. L' accés est refusé depuis une Iframe
    Par th0mas dans le forum Général JavaScript
    Réponses: 8
    Dernier message: 15/05/2008, 13h15
  2. Accès a un élement du document depuis une iframe
    Par highman dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 10/08/2007, 14h51
  3. Réponses: 19
    Dernier message: 15/05/2006, 21h52
  4. preload avec ciblage depuis une iframe
    Par jgoguel dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 18/10/2005, 10h42
  5. [C#] Redirection depuis une Iframe
    Par Dozer71 dans le forum ASP.NET
    Réponses: 2
    Dernier message: 24/05/2005, 10h36

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