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 :

Le 'this' d'un TD


Sujet :

JavaScript

  1. #1
    Membre à l'essai
    Inscrit en
    Mai 2002
    Messages
    25
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 25
    Points : 20
    Points
    20
    Par défaut Le 'this' d'un TD
    Salut,

    J'essaie de faire passer l'object 'this' dans le onMouseOver d'un TD mais cela ne passe pas ! Il me dit que l'objet n'est pas reconnu...
    Code:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    <td onMouseOver="Mouse_On_TDButton('this')">Valider</td>
     
    function Mouse_On_TDButton(e) {
      if(document.all) {
        document.getElementById(e).style.cursor='hand' ;
      } else {
        document.getElementById(e).style.cursor='pointer' ;
      }
    }
    Et l'erreur est:
    Erreur : document.getElementById(e) has no properties
    Ligne : 221

    Vous auriez une idée ?

    Merci,
    Vincent.

  2. #2
    Expert confirmé
    Avatar de siddh
    Inscrit en
    Novembre 2005
    Messages
    3 868
    Détails du profil
    Informations personnelles :
    Âge : 48

    Informations forums :
    Inscription : Novembre 2005
    Messages : 3 868
    Points : 5 011
    Points
    5 011
    Par défaut
    si tu veux faire un getElementById, passes le this.id
    si tu passes this, c est deja l'objet complet que tu envoit
    enfin a condition de pas mettre this entre '
    Alunissage : Procédé technique consistant à déposer des imbéciles sur un rêve enfantin.

    Cours | FAQ | Sources Javascript
    Cours | FAQ | Sources PHP
    Mes Articles

  3. #3
    Membre à l'essai
    Inscrit en
    Mai 2002
    Messages
    25
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 25
    Points : 20
    Points
    20
    Par défaut
    Citation Envoyé par siddh
    si tu veux faire un getElementById, passes le this.id
    si tu passes this, c est deja l'objet complet que tu envoit
    enfin a condition de pas mettre this entre '
    J'ai le même message d'erreur avec:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    <td onMouseOver="Mouse_On_TDButton(this)">Valider</td>
     
    function Mouse_On_TDButton(e) {
      if(document.all) {
        document.getElementById(e.id).style.cursor='hand' ;
      } else {
        document.getElementById(e.id).style.cursor='pointer' ;
      }
    }
    Y a un truc que j'ai pas du capter !

  4. #4
    Expert confirmé
    Avatar de siddh
    Inscrit en
    Novembre 2005
    Messages
    3 868
    Détails du profil
    Informations personnelles :
    Âge : 48

    Informations forums :
    Inscription : Novembre 2005
    Messages : 3 868
    Points : 5 011
    Points
    5 011
    Par défaut
    alors soit tu fais :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    <td onMouseOver="Mouse_On_TDButton(this.id)">Valider</td>
     
    function Mouse_On_TDButton(e) {
      if(document.all) {
        document.getElementById(e.id).style.cursor='hand' ;
      } else {
        document.getElementById(e.id).style.cursor='pointer' ;
      }
    }
    soit :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    <td onMouseOver="Mouse_On_TDButton(this)">Valider</td>
     
    function Mouse_On_TDButton(e) {
      if(document.all) {
        e.style.cursor='hand' ;
      } else {
        e.style.cursor='pointer' ;
      }
    }
    Alunissage : Procédé technique consistant à déposer des imbéciles sur un rêve enfantin.

    Cours | FAQ | Sources Javascript
    Cours | FAQ | Sources PHP
    Mes Articles

  5. #5
    Expert confirmé
    Avatar de javatwister
    Homme Profil pro
    danseur
    Inscrit en
    Août 2003
    Messages
    3 681
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : danseur

    Informations forums :
    Inscription : Août 2003
    Messages : 3 681
    Points : 5 221
    Points
    5 221
    Par défaut
    Il faut:
    soit déclarer "event" explicitement quand tu appelles la fonction;
    soit te passer d'event (puisque tu n'en as absolument pas besoin ici);


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    <td onmouseover="truc(this)">Valider</td> 
     
    function truc(obj) { 
    obj.style.cursor="pointer"// "pointer" est correctement interprété partout
    }
    ou

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    <td onmouseover="truc(event)">Valider</td> 
     
    function truc(e) { 
    obj= e.target ? e.target : e.srcElement;
    obj.style.cursor="pointer"// "pointer" est correctement interprété partout
    }

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

    Informations forums :
    Inscription : Avril 2004
    Messages : 7 649
    Points : 11 138
    Points
    11 138
    Par défaut Re: Le 'this' d'un TD
    Citation Envoyé par kult
    Salut,

    J'essaie de faire passer l'object 'this' dans le onMouseOver d'un TD mais cela ne passe pas ! Il me dit que l'objet n'est pas reconnu...
    Code:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    <td onMouseOver="Mouse_On_TDButton('this')">Valider</td>
     
    function Mouse_On_TDButton(e) {
      if(document.all) {
        document.getElementById(e).style.cursor='hand' ;
      } else {
        document.getElementById(e).style.cursor='pointer' ;
      }
    }
    Et l'erreur est:
    Erreur : document.getElementById(e) has no properties
    Ligne : 221

    Vous auriez une idée ?

    Merci,
    Vincent.
    ton td ne possède pas d'id, ce qui explique l'erreur sur document.getElementById()
    De plus this ne doit pas être entre ' ', sinon tu transmets une chaine de caractères (this ici) comme argument à ta fonction Mouse_On_TDButton(). Utilise la solution de javatwister
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    <td onmouseover="truc(this)">Valider</td>
     
    function truc(obj) {
    obj.style.cursor="pointer"// "pointer" est correctement interprété partout
    }
    Ici la focntion peut s'applique à n'importe quel objet de ta page HTML qui appelle la fonction truc().

Discussions similaires

  1. This.value au lieu de document.getElementById('field').value
    Par yoyot dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 04/03/2005, 14h02
  2. [MFC] Pointeur this et fonctions statiques
    Par Yellowmat dans le forum MFC
    Réponses: 5
    Dernier message: 08/02/2005, 10h15
  3. pb de fonction simple (this.form.submit()..)
    Par petitsims dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 14/01/2005, 09h29
  4. type de this
    Par julie29 dans le forum C++
    Réponses: 4
    Dernier message: 30/11/2004, 20h39
  5. [Oracle 9i] Erreur: wrong incarnation of this file
    Par shaun_the_sheep dans le forum Oracle
    Réponses: 5
    Dernier message: 26/11/2004, 10h53

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