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 :

[DOM] popup modification de src sous Firefox


Sujet :

JavaScript

  1. #1
    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 663
    Points
    66 663
    Billets dans le blog
    1
    Par défaut [DOM] popup modification de src sous Firefox
    J'ai bien trouvé dautres scripts qui fonctionnent, mais celui ci me turlupine (le premier qui dit de cheval ... )

    Sous IE pas de problème, sous FFX il refuse tout simpelement le path de l'image ???

    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
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=windows-1252">
    <title>Popup To Fit Image</title>
    <script type="text/javascript">
    <!--
    var w=window.open('','image','statusbar=no,toolbar=no,scrollbars=no,resizable=no');
     
    function PopupImage(image) { 
     
    var pic=w.document.createElement('img');
    w.ThePic=new Image();
    w.ThePic.PicPath=image;
    w.ThePic.src=w.ThePic.PicPath;
    pic.src=w.ThePic.src;
    pic.alt="coucou"
    w.document.body.appendChild(pic);
    //w.document.getElementsByTagName('img')[0].src=w.ThePic.src;
    w.document.body.style.margin='0px';
    w.document.close(); 
    if(w.document.images[0].complete){FitPic()}
    else {setTimeout(function(){FitPic(image)},100)}
    }
     
    function FitPic(image){
    var Hauteur=w.document.images[0].offsetHeight + 29
    var Largeur=w.document.images[0].offsetWidth+ 10;
    w.resizeTo(Largeur,Hauteur);
    var scW = screen.availWidth ? screen.availWidth : screen.width;
    var scH = screen.availHeight ? screen.availHeight : screen.height;
    w.moveTo(Math.round((scW-Largeur)/2),Math.round((scH-Hauteur)/2));}
     
     
    setTimeout(function(){PopupImage('Picture_5.jpg')},500)
    //-->
     
    </script>
    </head>
    je n'arrive tout simplement pas à savoir d'ou cela peut provenir ...

  2. #2
    Expert éminent sénior
    Avatar de Auteur
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    7 650
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 7 650
    Points : 11 141
    Points
    11 141
    Par défaut
    Voici un début de réponse :

    Citation Envoyé par Console firefox
    Erreur de sécurité : le contenu situé à about:blank ne peut pas charger de données ou établir un lien vers file:///c:/Mes%20documents/Picture_5.jpg.

  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 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 663
    Points
    66 663
    Billets dans le blog
    1
    Par défaut
    bon ben il ne me reste plus qu'a ouvir self.url en popup et la vider ?

  4. #4
    Expert éminent sénior
    Avatar de Auteur
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    7 650
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 7 650
    Points : 11 141
    Points
    11 141
    Par défaut
    Dans ce cas, j'ai une page blanche (avec Firefox en plus de l'erreur de sécurité, pas de problème avec IE) :
    Code javascript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
      pic.src=w.ThePic.src;
      pic.alt="coucou";

    Sinon si je remplace ce code par :
    Code javascript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
      pic.src=image;//w.ThePic.src;
      pic.alt="coucou";
    seul "coucou" s'affiche, je n'ai pas d'image sous Firefox (pas de problème avec IE)

    Idem si je précise about:blank dans le 1er paramètre de window.open()

    bon ben il ne me reste plus qu'a ouvir self.url en popup et la vider ?
    c'est à dire ?

  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 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 663
    Points
    66 663
    Billets dans le blog
    1
    Par défaut
    oui pas de probmème en revanche si tu utilise une page html vide ... mais bon ...
    l'idée est de ne pas utiliser de page externe ...

    c'est pour cela que je pensais à ouvir la même page dans la popup et en virer tout le contenu ...

  6. #6
    Expert éminent sénior
    Avatar de Auteur
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    7 650
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 7 650
    Points : 11 141
    Points
    11 141
    Par défaut
    Citation Envoyé par SpaceFrog
    oui pas de probmème en revanche si tu utilise une page html vide ... mais bon ...
    c'est ce que je viens de remarquer.. Si je fais un open vers une page vide de ce genre :
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    <html>
    <head>
    <title></title>
    </head>
     
    <body>
     
     
     
    </body>
     
    </html>
    J'ai une image....


    Citation Envoyé par SpaceFrog
    c'est pour cela que je pensais à ouvir la même page dans la popup et en virer tout le contenu ...
    c'est fastidieux....

  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 663
    Points
    66 663
    Billets dans le blog
    1
    Par défaut
    ben je ne vois pas d'autre solution ...

  8. #8
    Expert éminent sénior
    Avatar de Auteur
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    7 650
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 7 650
    Points : 11 141
    Points
    11 141
    Par défaut
    Est-ce qu'une page about:blank existe (au niveau du DOM), ou est-ce un artifice des navigateurs (qui affichent un écran blanc si la page a comme adresse about:blank )?

    Si la page blanche about:blank existe, elle devrait avoir par défaut cette structure :
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    <html>
     
    <head>
    <title></title>
     
    </head>
     
    <body>
     
    </body>
     
    </html>
    et ainsi on pourrait facilement inclure des objets, non ?

    Si c'est simplement un "aspect visuel", il faudrait donc construire cette page. (créer des balises html, head, body, ajouter les objets document, etc...).

  9. #9
    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 663
    Points
    66 663
    Billets dans le blog
    1
    Par défaut
    non a priori que tu mettes rien ou about:blank c'est le même tarif ...

  10. #10
    Expert éminent sénior
    Avatar de Auteur
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    7 650
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 7 650
    Points : 11 141
    Points
    11 141
    Par défaut
    Citation Envoyé par SpaceFrog
    non a priori que tu mettes rien ou about:blank c'est le même tarif ...
    j'ai vérifié avec l'inpecteur DOM de Firefox : la balise img est bien crée, l'attribut src correspond au chemin de l'image et le contenu de alt est bien défini.

  11. #11
    Expert éminent sénior
    Avatar de Auteur
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    7 650
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 7 650
    Points : 11 141
    Points
    11 141
    Par défaut
    Pour Firefox :
    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
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    {
      var pic=document.createElement('img'); //au lieu de w.document.createElement('img')
    
      w.ThePic=new Image();
      w.ThePic.PicPath=image;
      w.ThePic.src=w.ThePic.PicPath;
    
      pic.src=w.ThePic.src;
      pic.alt="coucou";
    
      w.document.body.appendChild(pic);
      //w.document.getElementsByTagName('img')[0].src=w.ThePic.src;
    
      w.document.body.style.margin='0px';
      //w.document.close();
    
      if(w.document.images[0].complete){FitPic()}
      else {setTimeout("FitPic()","2000")}
    
    }
    
    function FitPic()
    {
      var Hauteur=w.document.images[0].offsetHeight + 29
      var Largeur=w.document.images[0].offsetWidth+ 10;
      w.resizeTo(Largeur,Hauteur);
      var scW = screen.availWidth ? screen.availWidth : screen.width;
      var scH = screen.availHeight ? screen.availHeight : screen.height;
      w.moveTo(Math.round((scW-Largeur)/2),Math.round((scH-Hauteur)/2));
    }
    
     
    setTimeout(function(){PopupImage('Mes Images/i1.gif')},"500")

    Par contre le code ne fonctionne plus sous IE (ça le fait planter même).
    w.document.body.appendChild(pic); >> cette interface n'est pas prise en charge
    Le mieux est donc :
    Code javascript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    var pic=(document.all?w.document.createElement('img'):document.createElement('img'));


    J'ai légèrement modifé l'appel à la fonction FitPic() (j'ai supprimé le paramètre image et j'ai ralongé la tempo, pour voir ce qui se passait au niveau de la condition).

  12. #12
    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 663
    Points
    66 663
    Billets dans le blog
    1
    Par défaut
    arf j'avais justement ecarté la document.createElement car en principe l'éléemtn est propriété de la page ciblée...

  13. #13
    Expert éminent sénior
    Avatar de Auteur
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    7 650
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 7 650
    Points : 11 141
    Points
    11 141
    Par défaut
    Peut-être que Firefox n'autorise l'insertion d'éléments dans la fenêtre fille uniquement si ces éléments sont créés dans la page parent ?

  14. #14
    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 663
    Points
    66 663
    Billets dans le blog
    1
    Par défaut
    Mouaip ...
    Curieux comportement en tout cas.J'avais essayé par le passé de faire passer un element du parent vers la fille sans succès ... et là pour le coup c'est l'inverse !
    A n'y rien comprendre

  15. #15
    Expert éminent sénior
    Avatar de Auteur
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    7 650
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 7 650
    Points : 11 141
    Points
    11 141
    Par défaut
    Et avec Opéra Comment faut-il procéder ?

  16. #16
    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 663
    Points
    66 663
    Billets dans le blog
    1
    Par défaut
    ne pas surfer avec ?

  17. #17
    Membre expert
    Avatar de FremyCompany
    Profil pro
    Étudiant
    Inscrit en
    Février 2006
    Messages
    2 532
    Détails du profil
    Informations personnelles :
    Âge : 33
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2006
    Messages : 2 532
    Points : 3 239
    Points
    3 239
    Par défaut
    Citation Envoyé par Auteur
    Est-ce qu'une page about:blank existe (au niveau du DOM), ou est-ce un artifice des navigateurs (qui affichent un écran blanc si la page a comme adresse about:blank )?

    Si la page blanche about:blank existe, elle devrait avoir par défaut cette structure :
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    <html>
     
    <head>
    <title></title>
     
    </head>
     
    <body>
     
    </body>
     
    </html>
    et ainsi on pourrait facilement inclure des objets, non ?

    Si c'est simplement un "aspect visuel", il faudrait donc construire cette page. (créer des balises html, head, body, ajouter les objets document, etc...).
    Sous IE, elle existe, et y a même moyen de la changer (elle se trouve qqpart dans les dossiers windows)

  18. #18
    Expert éminent sénior
    Avatar de Auteur
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    7 650
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 7 650
    Points : 11 141
    Points
    11 141
    Par défaut
    Citation Envoyé par FremyCompany
    Sous IE, elle existe, et y a même moyen de la changer (elle se trouve qqpart dans les dossiers windows)
    et pour Firefox ?


    Sinon pour Opéra, quelle syntaxe utiliser ?
    Code javascript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    var pic = document.createElement('img');
    ou
    Code javascript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    var pic = w.document.createElement('img')
    ?

  19. #19
    Membre expert
    Avatar de FremyCompany
    Profil pro
    Étudiant
    Inscrit en
    Février 2006
    Messages
    2 532
    Détails du profil
    Informations personnelles :
    Âge : 33
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2006
    Messages : 2 532
    Points : 3 239
    Points
    3 239
    Par défaut
    Ceci est la seule syntaxe officielle
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    var pic = w.document.createElement('img')
    L'autre, j'ai déjà pu le constater marche sur IE, mais bloque sur FireFox

  20. #20
    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 663
    Points
    66 663
    Billets dans le blog
    1
    Par défaut
    Oui mais alors pourquoi cette syntaxe bloque-t-elle sous firefox ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    var pic = w.document.createElement('img')

+ Répondre à la discussion
Cette discussion est résolue.
Page 1 sur 2 12 DernièreDernière

Discussions similaires

  1. [DOM] DOM XML, ne marche pas sous Firefox
    Par Nass2 dans le forum Général JavaScript
    Réponses: 13
    Dernier message: 21/06/2008, 10h28
  2. Probleme de PopUp de type 'div' sous FireFox
    Par Alabama-song dans le forum ASP.NET
    Réponses: 3
    Dernier message: 31/08/2007, 12h42
  3. Modification propriété Left d'un calque sous firefox
    Par Chris74 dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 27/08/2007, 17h11
  4. Appel fonction et popup sous Firefox
    Par malbaladejo dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 24/07/2006, 11h18
  5. Réponses: 2
    Dernier message: 21/06/2006, 12h44

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