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] "This" et son scope


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    201
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2009
    Messages : 201
    Par défaut [POO] "This" et son scope
    Bonjour à tous!

    J'ai une interrogation, lorsque je suis dans mon objet JS. "this" fait référence à ce même objet (jusque là rien de délirant?).

    Mais, si mon objet lance un CallBack, et que cette fonction CallBack est déclaré dans mon objet: que vaut this?

    Un exemple peut pour concrétiser tout ça:
    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
     
    var MyObject = function()
    {
       this.param = 'value';
       this.Init = function()
       {
           alert(this.param); // Affiche value.
       }
     
       AnObject.AddListener('click', this.OnClickCallBack};
       this.OnClickCallBack()
       {
           alert(this.param); // affiche undefined
       }
    }
    vous auriez une idée?

  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
    AnObject.AddListener('click', this.OnClickCallBack};



    sinon essaye plutot avec cette syntaxe
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    AnObject.onclick=function(){this.OnclickCallBack();}
    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 éprouvé
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    201
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2009
    Messages : 201
    Par défaut
    Décidément je fais n'importe quoi quand je poste... un copier collé raté encore, il n'y a pas de soucis de syntaxe dons le code.

    Par contre je n'ai pas totalement la main sur l'objet envoyant le CallBack ,le code exact est:
    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
     
    var Gmaps = function(canva, address)
    {
        this.address = address;
        this.minimizedCanva = canva;
        this.map = null;
        this.Init = function()
        {
            this.map = new GMap2($(this.minimizedCanva));
     
            Gmaps_ClientGeocoder.getLocations(this.address, function(response)
            {
                this.map.clearOverlays(); // ici map n'existe pas, pourtant déclarer dans Gmaps.
                // ...
            });
        }
    Dans le CallBack de Gmaps_ClientGeocoder.getLocations, this fait référence a la méthode elle même (par exemple this.response existe, et renvoie le paramètres de la méthode).

    Mais comment pourrais-je avoir accès à l'instance de mon objet Gmaps?

  4. #4
    Membre très actif
    Inscrit en
    Janvier 2009
    Messages
    598
    Détails du profil
    Informations forums :
    Inscription : Janvier 2009
    Messages : 598
    Par défaut
    ça te sert à quoi le callback ? (je sais meme pas ce que c'est^^)

    Peut-etre qu'on peut faire plus simple pour ce que tu veux faire ?

  5. #5
    Membre éprouvé
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    201
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2009
    Messages : 201
    Par défaut
    Les callback sont utilisé pour des opération asynchrone. En javascript ça se traduit généralement par de l'ajax.

    Par exemple, je lance une requête vers une page quelconque. Le code javascript n'attend pas le retour. Il continue sont execution. Et pouf dès qu'il y a un retour, il exécute ton CallBack, qui est fait une méthode.


    Donc là, dans ce que je souhaite faire. Lorsque que la méthode Gmaps_ClientGeocoder.getLocations a abouti, elle execute ma function passé en paramètres (le deuxième paramètres pour tout simplement être le nom d'une méthode).

  6. #6
    Membre très actif
    Inscrit en
    Janvier 2009
    Messages
    598
    Détails du profil
    Informations forums :
    Inscription : Janvier 2009
    Messages : 598
    Par défaut
    Merci de l'info, mais pourquoi as-tu besoin d'apeler une méthode de ton objet de cette façon ? Ne peux-tu pas l'appeler de façon normale et directement ?
    (Normalement si)

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

Discussions similaires

  1. onmouseover="Menu_HoverStatic(this)" object expected
    Par cyrano_de_bergerac dans le forum ASP.NET
    Réponses: 0
    Dernier message: 01/10/2010, 16h01

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