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 :

[POO][Gestionnaire d'événement déclaré comme méthode d'une classe]


Sujet :

JavaScript

  1. #1
    Membre habitué
    Inscrit en
    Mars 2007
    Messages
    185
    Détails du profil
    Informations personnelles :
    Âge : 51

    Informations forums :
    Inscription : Mars 2007
    Messages : 185
    Points : 134
    Points
    134
    Par défaut [POO][Gestionnaire d'événement déclaré comme méthode d'une classe]
    Bonjour,

    Je suis en train de créer une classe JS que je veux générique et simple à utiliser. Dans sa conception j'ai donc intégré les gestionnaires d'événements sur les objets qu'elle crée à l'intérieur de la classe. Ce qui donne quelque chose du genre:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    var maSuperClass = function(){
              [......... suizz..........]
              this.divOnMouseDown = function(){
    		this.obj_input_field.value = this.getValue(this);
    		this.obj_form.submit();
    		}
     
              this.obj_div.onmousedown = this.divOnMouseDown;
              }
    Et bien sur ça ne marche pas car le gestionnaire d'événements JS onmousedown attend une fonction et non une méthode d'une classe. J'ai envisagé d'utiliser des méthodes statiques en les sortant de ma classe ; mais malheureusement dans les méthodes qui vont gérer les événements je fais références à des méthodes non statiques de ma classe (this.). Je veux éviter de transformer toute ma classe en collection de méthodes statiques...

    Y'a t'il une solution pour gérer proprement ce problème?

    Merci, Théolude.

  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 portée du mot clé this
    Salut,

    C'est un problème de portée de this et non de méthode ou fonction :
    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
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
      <title>portée de this</title>
      <meta http-equiv="Content-type" content="text/html; charset=UTF-8" />
      <style type="text/css">
      * {margin:0;padding:0;}
      body {margin:10px;background:#000;color:#ddd;font-size:1em;font-family:Helvetica, Arial, sans-serif;}
      div {width:10em;height:3em;background:#333;}
      </style>
    </head>
    <body>
      <script type="text/javascript">
      <!--
        var FC = function() {
          this.div = document.createElement("div");
          this.tn = document.createTextNode("on clique ici");
          this.div.appendChild(this.tn);
          document.body.appendChild(this.div);
          var me = this;
          this.a = function() {
            alert(this.tn +" - "+ me.tn.textContent);
          }
          this.div.onmousedown = this.a;
        }
        var fc1 = new FC();
      //-->
      </script>
    </body>
    </html>
    Les Cours et tutoriels JavaScript
    Penser à la recherche et au bouton

  3. #3
    Membre habitué
    Inscrit en
    Mars 2007
    Messages
    185
    Détails du profil
    Informations personnelles :
    Âge : 51

    Informations forums :
    Inscription : Mars 2007
    Messages : 185
    Points : 134
    Points
    134
    Par défaut
    Citation Envoyé par franculo_caoulene Voir le message
    Salut,
    C'est un problème de portée de this et non de méthode ou fonction [/CODE]
    Merci de ta réponse ... et désolé de l'ineptie de ma remarque.
    Mais que dans une méthode d'une classe, l'opérateur this ne puisse pas faire référence à une propriété ou une méthode de la classe .... je ne comprends pas

    J'ai essayé ton exemple, et effectivement dans ta méthode a, les références à this.tn ou me.tn.textContent sont null.

    J'ai pris mes petits doigts, j'ai fait une recherche et je suis tombé sur ça : http://www.developpez.net/forums/d45...variable-this/ ... j'essaye et je vous tiens au courant.

    Merci de ton aide, Théolude

  4. #4
    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
    hop hop hop! ce que je propose est la bonne solution. C'est juste que textNode.textContent n'est pas pris en compte par IE8 (c'est nouveau?). me.tn fonctionnera partout.

    edit : textContent n'a jamais fonctionné sous IE!
    Les Cours et tutoriels JavaScript
    Penser à la recherche et au bouton

  5. #5
    Membre habitué
    Inscrit en
    Mars 2007
    Messages
    185
    Détails du profil
    Informations personnelles :
    Âge : 51

    Informations forums :
    Inscription : Mars 2007
    Messages : 185
    Points : 134
    Points
    134
    Par défaut
    Citation Envoyé par franculo_caoulene Voir le message
    hop hop hop! ce que je propose est la bonne solution. C'est juste que textNode.textContent n'est pas pris en compte par IE8 (c'est nouveau?). me.tn fonctionnera partout.
    Je te confirme sous IE 8, je récupère undefined et undefined dans les deux cas. Ca ne va sacrément pas arranger mes affaires cette histoire ...

    Théolude

    NB: Toutes mes confuses, erreur de codage dans mon test, ton diagnostique était le bon textContent n'est apparemment pas supporté sous IE8.

  6. #6
    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
    Oublie textContent, la façon de faire fonctionne.
    Les Cours et tutoriels JavaScript
    Penser à la recherche et au bouton

  7. #7
    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 : 53
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut
    Salut,
    Je confirme que la solution de franculo est la bonne
    En revanche, pour ton problème, il y a une raison de passer par une propriété "exotique" plutôt que par nodeValue ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    var test = document.createTextNode('Toto');
    alert(test.nodeValue);
    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

  8. #8
    Membre habitué
    Inscrit en
    Mars 2007
    Messages
    185
    Détails du profil
    Informations personnelles :
    Âge : 51

    Informations forums :
    Inscription : Mars 2007
    Messages : 185
    Points : 134
    Points
    134
    Par défaut
    Citation Envoyé par Bovino Voir le message
    Salut,
    Je confirme que la solution de franculo est la bonne
    En revanche, pour ton problème, il y a une raison de passer par une propriété "exotique" plutôt que par nodeValue ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    var test = document.createTextNode('Toto');
    alert(test.nodeValue);
    C'est le test de Franculo qui utilisait TextContent Je ne l'utilise pas dans mon script.

    Théolude

  9. #9
    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
    Voilà! merci Bovino, c'est nodeValue que j'utilise d'habitude!
    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
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
      <title>portée de variable</title>
      <meta http-equiv="Content-type" content="text/html; charset=UTF-8" />
      <style type="text/css">
      * {margin:0;padding:0;}
      body {margin:10px;background:#000;color:#ddd;font-size:1em;font-family:Helvetica, Arial, sans-serif;}
      div {width:10em;height:3em;background:#333;}
      </style>
    </head>
    <body>
      <script type="text/javascript">
      <!--
        var FC = function() {
          this.div = document.createElement("div");
          this.tn = document.createTextNode("on clique ici");
          this.div.appendChild(this.tn);
          document.body.appendChild(this.div);
          var me = this;
          this.a = function() {
            alert(this.tn +" - "+ me.tn.nodeValue);
          }
          this.div.onmousedown = this.a;
        }
        var fc1 = new FC();
      //-->
      </script>
    </body>
    </html>
    textContent fait partie du DOM Core 3, c'est exotique aujourd'hui, mais demain ce sera banal...
    Les Cours et tutoriels JavaScript
    Penser à la recherche et au bouton

  10. #10
    Membre habitué
    Inscrit en
    Mars 2007
    Messages
    185
    Détails du profil
    Informations personnelles :
    Âge : 51

    Informations forums :
    Inscription : Mars 2007
    Messages : 185
    Points : 134
    Points
    134
    Par défaut
    Et pour en revenir au problème initial ...

    Si j'utilise un setTimeout dans ma classe, et que je veux appeler une méthode de ma classe dans ce timeout... je fais comment

    Théolude

  11. #11
    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
    De la même façon :
    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
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
      <title>portée de variable</title>
      <meta http-equiv="Content-type" content="text/html; charset=UTF-8" />
      <style type="text/css">
      * {margin:0;padding:0;}
      body {margin:10px;background:#000;color:#ddd;font-size:1em;font-family:Helvetica, Arial, sans-serif;}
      div {width:10em;height:3em;background:#333;}
      </style>
    </head>
    <body>
      <script type="text/javascript">
      <!--
        var FC = function() {
          this.div = document.createElement("div");
          this.tn = document.createTextNode("on clique ici");
          this.div.appendChild(this.tn);
          document.body.appendChild(this.div);
          var me = this;
     
          this.st = setTimeout(function() {
            me.a();
          }, 500);
     
          this.a = function() {
            alert(this.tn +" - "+ me.tn.nodeValue);
          }
          this.div.onmousedown = this.a;
        }
        var fc1 = new FC();
      //-->
      </script>
    </body>
    </html>
    Les Cours et tutoriels JavaScript
    Penser à la recherche et au bouton

  12. #12
    Membre habitué
    Inscrit en
    Mars 2007
    Messages
    185
    Détails du profil
    Informations personnelles :
    Âge : 51

    Informations forums :
    Inscription : Mars 2007
    Messages : 185
    Points : 134
    Points
    134
    Par défaut
    Oui effectivement c'est évident et je me sens tout débile d'avoir poser la question... à ma décharge je ne pensais pas qu'on pouvait définir "on the fly" la fonction appelée par setTimeout.

    Merci beaucoup pour tes (vos) conseils... je fréquente régulièrement les forums de developpez, et il arrive plus souvent que je me réponde à mes propres questions, plutôt que quelqu'un vienne m'aider à résoudre mon problème !!

    Théolude

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

Discussions similaires

  1. Réponses: 7
    Dernier message: 27/02/2015, 12h59
  2. Réponses: 3
    Dernier message: 29/04/2008, 14h14
  3. [POO] Ecraser une méthode d'une classe
    Par fwdavy dans le forum Langage
    Réponses: 5
    Dernier message: 22/04/2008, 18h15
  4. Réponses: 5
    Dernier message: 23/04/2007, 16h31
  5. [POO]Appelé une méthode d'une classe mère
    Par LE NEINDRE dans le forum Langage
    Réponses: 2
    Dernier message: 14/12/2005, 14h44

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