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 :

attachEvent, this non reconnu


Sujet :

JavaScript

  1. #1
    Membre régulier
    Homme Profil pro
    Développeur Web
    Inscrit en
    Décembre 2006
    Messages
    105
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Décembre 2006
    Messages : 105
    Points : 119
    Points
    119
    Par défaut attachEvent, this non reconnu
    Bonjour,

    Je suis tombé sur un truc rigolo (ou pas), je viens de voir en travaillant une lib que IE n'interprète pas le "this" dans la situation suivante alors qu'avec l'equivalent addEventListener ca passe sans probleme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    obj.attachEvent("onclick", function(){document.title = this.innerHTML;}, true);
    // IE plantera a cause de "this" et affichera undefined
    J'ai tenté de faire quelque chose avec une closure et Apply mais du coup la fonction n'est plus enlevable avec les fonctions adéquates.

    Ceci étant, je voudrai savoir s'il y a possibilité de le faire reconnaitre d'une façon ou d'une autre sur IE !

    J'ai fais une page de base pour bien se rendre compte de la chose :
    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
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
     
    <html>
    <head>
    </head>
    <body>
     
    <div id="toto">kikou</div>
     
    <script type="text/javascript">
     
    // appellera la fonction lit() au click sur "toto" 
    addEvent(document.getElementById("toto"), "click", lit);
     
     
    function lit()
    {
            // normalement, doit afficher le contenu de "toto" et enleve l'ecouteur
            // mais sur IE, ce fameux "this" n'est pas pris en compte
    	alert(this.innerHTML);
    	removeEvent(document.getElementById("toto"), "click", lit);
    }
     
    // fonctions pratiques
    function addEvent(obj, ev, fct)
    {
    	if(obj.attachEvent)
    	{
    		obj.attachEvent("on" + ev, fct, true);
    	}
    	else
    	{
    		obj.addEventListener(ev, fct, true);
    	}
    }
     
    function removeEvent(obj, ev, fct)
    {
    	if(obj.detachEvent)
    	{
    		obj.detachEvent("on" + ev, fct, true);
    	}
    	else
    	{
    		obj.removeEventListener(ev, fct, true);
    	}
    }
     
    </script>
    </body>
    </html>
    voila, la réponse est peut etre toute bete.

    Merci d'avance

  2. #2
    Membre émérite Avatar de franculo_caoulene
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    2 880
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 2 880
    Points : 2 953
    Points
    2 953
    Par défaut
    Salut,

    Il faut plutôt utiliser ce genre de syntaxe
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    var fn = function(e) {
      var elm = e.target || event.srcElement;    //<-- détecte la source de l'évènement
      alert("action suite à un évènement en cours.");
      return false;
    };
    this que ce soit en utilisant addEventListener ou attachEvent ne retourne jamais l'élément en cours, mais plutôt l'objet window.
    Les Cours et tutoriels JavaScript
    Penser à la recherche et au bouton

  3. #3
    Membre régulier
    Homme Profil pro
    Développeur Web
    Inscrit en
    Décembre 2006
    Messages
    105
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Décembre 2006
    Messages : 105
    Points : 119
    Points
    119
    Par défaut
    Je t'assure qu'en dehors de IE, "this" me renvoit l'élément courrant, tu peux tester avec le code que j'ai mis au dessus.
    IE renvoit bien "window" par contre.

    Sinon j'ai trouvé ce bout de code
    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
     
    function addEvent(obj, type, fn, par){
     
      if(obj.addEventListener){
     
        obj.addEventListener(type, function(event){        
     
          return fn.call(obj, event, par);
     
        }, false );
     
      }else if(obj.attachEvent){
     
        obj.attachEvent("on"+type, function(e){
     
          if (!e) var e = window.event;   
     
          return fn.call(obj, e, par);
     
        });
     
      }
     
    }
    C'est une façon sûre de procédé vu que l'on obtient ce que l'on cherche.
    C'est quasiment ce que j'avais fait auparavant mais comme je disais, on ne peut pas retirer l'événement.
    S'il n'y a pas d'autre façon de procéder, comment pourrait on faire, dans le cadre ou c'est un code similaire qui est utilisé, pour pouvoir retirer l'événement (detachEvent, removeEventListener) ?

  4. #4
    Expert confirmé
    Avatar de emmanuel.remy
    Inscrit en
    Novembre 2005
    Messages
    2 855
    Détails du profil
    Informations personnelles :
    Âge : 55

    Informations forums :
    Inscription : Novembre 2005
    Messages : 2 855
    Points : 4 045
    Points
    4 045
    Par défaut
    Salut,

    @hakurou: Dans le cas des événements traditionnels (onclick=...) le this de IE pointe bien vers l'élément du DOM concerné, mais par contre via attachEvent('onclick',... , le this pointe vers l'objet window.

    Evidemment d'après le W3C, le this devrait toujours pointer vers l'élément...

    ERE
    Quand une tête pense seule, elle devient folle.

  5. #5
    Membre émérite Avatar de franculo_caoulene
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    2 880
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 2 880
    Points : 2 953
    Points
    2 953
    Par défaut
    J'ai essayé de faire un attachEvent à l'épreuve des balles, utilise plutôt la version courte qui est mieux.
    Les Cours et tutoriels JavaScript
    Penser à la recherche et au bouton

  6. #6
    Membre régulier
    Homme Profil pro
    Développeur Web
    Inscrit en
    Décembre 2006
    Messages
    105
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Décembre 2006
    Messages : 105
    Points : 119
    Points
    119
    Par défaut
    Justement, j'étais en train de réfléchir sur l'idée de stocker les événements comme le font Mootools et YUI, et je vois que dans ton code tu les stocke dans un Array aussi, et en plus grâce a ca, ca fonctionne.

    Je vous remercie de votre aide précieuse, passez une bonne journée !

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

Discussions similaires

  1. [POO] this.parent non reconnu ! !
    Par sylv1-69 dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 29/03/2008, 11h20
  2. Commandes non reconnues.
    Par Manu' dans le forum Administration système
    Réponses: 3
    Dernier message: 07/10/2004, 17h09
  3. [EJB] [JSP] Méthode EJB non reconnue dans jsp
    Par stago dans le forum Servlets/JSP
    Réponses: 2
    Dernier message: 06/07/2004, 09h52
  4. Creation de table, caractère non reconnu
    Par Missvan dans le forum PostgreSQL
    Réponses: 2
    Dernier message: 17/02/2004, 13h28
  5. xslt_create() non reconnu
    Par BRAUKRIS dans le forum XML/XSL et SOAP
    Réponses: 2
    Dernier message: 11/12/2003, 14h43

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