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 :

onmouseout et IE


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Septembre 2009
    Messages
    36
    Détails du profil
    Informations forums :
    Inscription : Septembre 2009
    Messages : 36
    Par défaut onmouseout et IE
    Bonjour à tous,

    Je suis confronté à un problème. Au survol de la souris je créer unediv auquel j'associe une classe. Une fois que le survol n'est plus actif j'efface mon div créer. Tout fonctionne sur FF et Chrome mais j'ai une erreur dans mon script avec IE. Il créer bien mon div mais ne l'efface pas..

    Quel serais le problème ?

    Merci

    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
     
    <script type="text/javascript">
    function fenetre(titre,url,left,top) {
     
    var larg = (window.innerWidth);
    larg = larg /2;
    larg = larg - 405;
    larg = parseInt(larg,10)+ parseInt(left,10);
     
    var haut = parseInt(top,10) + 80+20;
     
    var monCalque=document.createElement('div');
    var test =document.getElementById("carteL");
    monCalque.setAttribute("class","maclasse");
    monCalque.setAttribute("className","maclasse");
    monCalque.style.left = left+'px';
    monCalque.style.top = haut+'px';
    monCalque.style.position = 'absolute';
     
    monCalque.innerHTML="<a href='"+url+"'>"+titre+"</a>";
    test.appendChild(monCalque);
    }
     
    function close_fen() {
     
    document.getElementById("carteL").removeChild(document.getElementsByClassName("maclasse")[0]);
     
    }
    et l'appel onmouseover="fenetre('ville','#','225','500');" onmouseout="close_fen();"

  2. #2
    Membre Expert
    Avatar de RomainVALERI
    Homme Profil pro
    POOête
    Inscrit en
    Avril 2008
    Messages
    2 652
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : POOête

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 652
    Par défaut
    J'ai un doute sur la prise en compte correcte de setAttribute selon les versions d'IE... quelqu'un peut confirmer ? ^^

    En attendant et juste par curiosité, webpxis, tu peux toujours faire un test en utilisant la "vieille méthode", histoire de voir si ça fait la même chose sous IE :
    Code javascript : Sélectionner tout - Visualiser dans une fenêtre à part
    monCalque.className = "maclasse";

  3. #3
    Invité
    Invité(e)
    Par défaut
    normalement avec ie 6 et 7 hormis les ajouts d'evenement setattribute fonctionnement bien, mois ce qui me fait douter c'est

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    monCalque.setAttribute("className","maclasse");
    className n'est pas un attribut mais une proprieté il me semble et il est possible que ie arret le script a cette endroit.

  4. #4
    Membre Expert
    Avatar de RomainVALERI
    Homme Profil pro
    POOête
    Inscrit en
    Avril 2008
    Messages
    2 652
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : POOête

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 652
    Par défaut
    Citation Envoyé par mekal Voir le message
    normalement avec ie 6 et 7 hormis les ajouts d'evenement ...
    Voilà je me disais bien que ça me rappelait quelque chose
    Bon en l'occurrence c'était pas ça le problème

    Mais la remarque de Mekal est très pertinente : c'est une bonne piste de résolution ^^

  5. #5
    Membre Expert
    Profil pro
    Inscrit en
    Mars 2002
    Messages
    1 132
    Détails du profil
    Informations personnelles :
    Âge : 53
    Localisation : France

    Informations forums :
    Inscription : Mars 2002
    Messages : 1 132
    Par défaut
    Bonjour,

    Essayes de faire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    var aSupprimer = document.getElementsByClassName("maclasse")[0];
    aSupprimer.parentNode.removeChild(aSupprimer);
    devyan

  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
    Billets dans le blog
    20
    Par défaut
    getElementsByClassName n'est pas implémenté dans IE
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  7. #7
    Invité
    Invité(e)
    Par défaut
    une fonction qui devrait marcher sa fait un peut tordu mais sa a la particularite d'etre compatible ie 6

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    function close_fen() {
    if(document.getElementById("carteL").hasChildNodes()){
    var all= document.getElementById("carteL").getElementsByTagName("*");
    if(all){
    for (var i=0;i<all.length;i++){
     
    if(all[i].className=="maclasse"){
    document.getElementById("carteL").removeChild(all[i]);
    i--
    }
    }
    }    
    }
    }

  8. #8
    Membre averti
    Inscrit en
    Septembre 2009
    Messages
    36
    Détails du profil
    Informations forums :
    Inscription : Septembre 2009
    Messages : 36
    Par défaut
    Mon soucis c'est que je ne peux créer d'id car il y a plein div qui ce génére sur une carte et qui peuvent se chevaucher. L'avantage de la class c'est que sa me parait plus simple à gérér.

Discussions similaires

  1. [javascript]Modifier onMouseOut
    Par groum999 dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 20/12/2005, 11h34
  2. OnMouseOut et Over
    Par TommyWeb dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 02/09/2005, 20h57
  3. probleme onmouseout avec firefox
    Par laurent2004 dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 02/09/2005, 08h23
  4. onClick/onMouseOver/onMouseOut + <a href>+<img>
    Par lipczynski dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 10/11/2004, 14h53
  5. Probleme "onmouseout" sur IE seule
    Par softflowe dans le forum Balisage (X)HTML et validation W3C
    Réponses: 5
    Dernier message: 06/10/2004, 14h04

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