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

jQuery Discussion :

Récupérer les attributs d'un lien cliqué


Sujet :

jQuery

  1. #1
    Membre averti Avatar de renaud26
    Homme Profil pro
    Webmaster
    Inscrit en
    Mars 2003
    Messages
    1 365
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mars 2003
    Messages : 1 365
    Points : 436
    Points
    436
    Par défaut Récupérer les attributs d'un lien cliqué
    Bonjour à tous,

    Sur ce lien :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <a onclick="faisceci()" href="index.php">Lien</a>
    Comment je peux, dans la fonction, récupérer les attributs du lien ? (sans bien sûr le passer en paramètre, ni lui attribuer une classe...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    function faisceci(){
    alert( $(this) ); // retourne "object"
    alert( $(this).attr("href") ); // retourne "undefined"
    }
    Merci beaucoup pour vos lumières.

  2. #2
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 048
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 048
    Points : 44 562
    Points
    44 562
    Par défaut
    Bonjour,
    dans la fonction une simple utilisation du this devrait suffire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    function faisceci(){
      alert( this);
      alert( this.href);
    }

  3. #3
    Membre averti Avatar de renaud26
    Homme Profil pro
    Webmaster
    Inscrit en
    Mars 2003
    Messages
    1 365
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mars 2003
    Messages : 1 365
    Points : 436
    Points
    436
    Par défaut
    Bonjour et merci de ta réponse,
    Mais...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    alert( this.href );
    Retourne undefined...

    Et

    Retourne Object Window

  4. #4
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 048
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 048
    Points : 44 562
    Points
    44 562
    Par défaut
    oups !
    pas vue la façon d'appeler la fonction, effectivement this dans ce cas est le contexte global.
    Dans ton cas il te faut récupérer l'élément ayant déclenché l'événement
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    function faisceci( e){
      e = e||event;
      obj = e.target ||e.srcElement;
      alert( obj.tagName);
      alert( obj.href);
    }
    avec un appel légèrement modifier
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <a onclick="faisceci(event)" href="index.php">Lien</a>

  5. #5
    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
    Citation Envoyé par NoSmoking
    oups !
    pas vue la façon d'appeler la fonction, effectivement this dans ce cas est le contexte global.
    Dans ton cas il te faut récupérer l'élément ayant déclenché l'événement
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    function faisceci( e){
      e = e||event;
      obj = e.target ||e.srcElement;
      alert( obj.tagName);
      alert( obj.href);
    }
    avec un appel légèrement modifier
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <a onclick="faisceci(event)" href="index.php">Lien</a>
    NoSmoking, tu te compliquerais pas un peu la vie ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    function faisceci(elem){
      alert( obj.tagName);
      alert( obj.href);
    }
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <a onclick="faisceci(this)" href="index.php">Lien</a>
    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

  6. #6
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 048
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 048
    Points : 44 562
    Points
    44 562
    Par défaut
    je ne suis pas à en forme ce soir, mais sur ce coup je répond au cahier des charges
    Citation Envoyé par renaud26 Voir le message
    Comment je peux, dans la fonction, récupérer les attributs du lien ? (sans bien sûr le passer en paramètre, ni lui attribuer une classe...
    et comme on est sur le forum jQuery je pense qu'un affectation direct de la fonction serait le plus judicieux
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    $('#id_element').click(function() {
      alert( this.href);
    });
    ou un truc dans le style.

  7. #7
    Membre averti Avatar de renaud26
    Homme Profil pro
    Webmaster
    Inscrit en
    Mars 2003
    Messages
    1 365
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mars 2003
    Messages : 1 365
    Points : 436
    Points
    436
    Par défaut
    Merci beaucoup à vous deux !

    La méthode de Bovino est super efficace, c'est impec.
    NoSmokink, ça fonctionne aussi mais c'est un peu plus lourd.
    Je ne peux pas trop mettre des ID sur les liens, j'en ai plein la page...
    Et puis il y a des paramètres dans la fonction, envoyés par une boucle PHP.

    Et tout cas, ce forum est vraiment toujours le top des tops, avec des gens aussi sympa que compétents.

    Bonne soirée à vous.

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

Discussions similaires

  1. [DOM] Récupérer les attributs d'un fichier XML en PHP
    Par ePsymon dans le forum Bibliothèques et frameworks
    Réponses: 2
    Dernier message: 08/02/2008, 11h51
  2. [DOM] Récupérer les attributs d'une classe CSS ?
    Par titoumimi dans le forum Général JavaScript
    Réponses: 13
    Dernier message: 10/07/2007, 14h33
  3. [Débutant]Récupérer les attributs/paramètre d'un dossier
    Par Bloodscalp dans le forum Entrée/Sortie
    Réponses: 4
    Dernier message: 13/10/2006, 15h06
  4. [DOM Javascript]Récupérer les attributs
    Par gabychon dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 02/05/2006, 15h21
  5. [VB.Net] Comment récupérer les Attributs LDAP ?
    Par le Daoud dans le forum VB.NET
    Réponses: 6
    Dernier message: 03/03/2006, 11h45

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