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 :

Onclick sur un bouton contenant un élément <p></p>


Sujet :

JavaScript

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2007
    Messages : 12
    Points : 7
    Points
    7
    Par défaut Onclick sur un bouton contenant un élément <p></p>
    Bonjour,

    Si je fais un bouton sur ma page <div id='monbouton' onclick='mafonction(event)'>MON BOUTON</div>, tout se passe bien.

    Cependant, si je transforme mon bouton de cette façon ( dans un but de centrer correctement le contenu du bouton )

    <div id='monbouton' onclick='mafonction(event)'><p>MON BOUTON</p></div> , si je clique sur le texte, le bouton réagit mais n'envoie pas l'id correct, il me semble que tout se passe comme si c'est l'élément p qui réagit.

    Comment faire pour récupérer l'id du div qui doit réagir au clic.

  2. #2
    Modérateur
    Avatar de ProgElecT
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2004
    Messages
    6 077
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 68
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Décembre 2004
    Messages : 6 077
    Points : 17 171
    Points
    17 171
    Par défaut
    Salut

    Et si tu mets l'action click sur le <P><div id='monbouton'><p onclick='mafonction(event)'>MON BOUTON</p></div> ?
    Soyez sympa, pensez -y
    Balises[CODE]...[/CODE]
    Balises[CODE=NomDuLangage]...[/CODE] quand vous mettez du code d'un autre langage que celui du forum ou vous postez.
    Balises[C]...[/C] code intégré dans une phrase.
    Balises[C=NomDuLangage]...[/C] code intégré dans une phrase quand vous mettez du code d'un autre langage que celui du forum ou vous postez.
    Le bouton en fin de discussion, quand vous avez obtenu l'aide attendue.
    ......... et pourquoi pas, pour remercier, un pour celui/ceux qui vous ont dépannés.
    👉 → → Ma page perso sur DVP ← ← 👈

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2007
    Messages : 12
    Points : 7
    Points
    7
    Par défaut Si c'était si simple ;)
    Merci pour votre réponse, mais cela ne corresponds pas à ce que je souhaite.

    Dans ce cas, seul le texte est actif, le but est que l'ensemble du bouton soit actif.

  4. #4
    Modérateur

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

    Informations forums :
    Inscription : Janvier 2011
    Messages : 16 959
    Points : 44 122
    Points
    44 122
    Par défaut
    Bonjour,
    commence par supprimer la gestion du onclick du HTML, on l’enlève du contenu de la balise et utilise addEventListener pour affecter une action à l’événement click sur ton élément.

    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    <div id="monbouton">
      <!--
      là tu mets ce que tu veux
      -->
    </div>
    et ensuite tu incorpores le script suivant, après la déclaration de ton élément dans le HTML, :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    const oBtn = document.getElementById("monbouton");
    oBtn.addEventListener( "click", function (ev) {
      console.log("élément cliqué :", this);
      console.log("détails e :", ev);
    });

  5. #5
    Futur Membre du Club
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2007
    Messages : 12
    Points : 7
    Points
    7
    Par défaut C'est quoi ce "this"
    Bonjour, Le code HTML est généré au vol via AJAX, le fait d'ajouter à mes balises les évènements dans le code HTML me facilite la tâche, sinon, il faudrait que j'envoie le code HTML et ensuite attacher à tous les éléments les évènements associés.

    Effectivement, il y a une différence et je ne vous cache pas que cela m'ennuie.

    J'ai fait donc 3 boutons et je suis perplexe, dans votre exemple, j'ai un élément this.id qui donne l'id du div dans tous les cas et target.id qui n'a la valeur du div que si je clique en dehors de l'élément <p>

    Dans les autres cas, il semble que this.id est undefined, et target.id se comporte de la même façon.

    Je joins le code et j'espère que vous avez une idée.

    Code HTML : 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
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    <style>
    /* pour centrer dans le bouton, il faut ajouter un élément <p> */
    .my_btn {
            display:flex;
            margin:3px;
            padding:3px;
            font:bold 20px Arial;
            background:#f5f5f5;
            color:#555;
            border-radius:3px;
            border:1px solid #555;
            box-shadow:1px 1px 3px #999;
            cursor:pointer;
            text-align:center;
            height:40px;
    }
     
    .my_btn p {
            text-align: center;
            margin:auto;
    }
    </style>
     
     
     
    <div id="monbouton" class='my_btn'>
    <p>TEST</p>
    </div>
     
    <div id="monbouton2" class='my_btn' onclick="f(event)" >
    <p>TEST 2</p>
    </div>
     
    <div id="monbouton3" class='my_btn'>
    <p>TEST 3</p>
    </div>
     
     
    <script>
    const oBtn = document.getElementById("monbouton");
    oBtn.addEventListener( "click", function (ev) {
            if( !ev ) ev = window.event;
        var target = ev.target || ev.srcElement; 
            
            alert("élément cliqué :"+this+' '+this.id+' '+target.id);
            alert("détails e :"+ev);
    });
     
    const oBtn2 = document.getElementById("monbouton3");
    oBtn2.addEventListener("click",function (ev) {f(ev)});
     
    function f(ev)
    {
            if (!ev ) { ev = window.event; alert("no ev"); }
        var target = ev.target || ev.srcElement; 
     
            alert("élément cliqué sur test 2 :"+this.id+' '+target.id);
            alert("détails e :", ev);
     
    }

  6. #6
    Futur Membre du Club
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2007
    Messages : 12
    Points : 7
    Points
    7
    Par défaut CurrentTarget est la solution
    En analysant le contenu des variables via l'outil de développement de Chrome, j'ai vu une propriété qui semble être la solution.
    Il s'agit de ev.currentTarget.id.

    merci à NoSmoking qui m'a mis sur la piste

  7. #7
    Modérateur

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

    Informations forums :
    Inscription : Janvier 2011
    Messages : 16 959
    Points : 44 122
    Points
    44 122
    Par défaut
    Tu n'auras pas forcément le résultat escompté avec ev.currentTarget.id.
    Concernant ton code il te faut factoriser pour ne pas faire de la duplication de code, par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    // récup. des éléments ayant la class my-btn pour boucler dessus
    const oBtns = document.querySelectorAll(".my_btn");
    oBtns.forEach(function (el) {
      el.addEventListener("click", function (ev) {
        // call() pemet d'utiliser « this » dans la fonction appelée 
        // et qui ne sera autre que « e »
        fct.call(el, ev);
      });
    });
     
    function fct(ev) {
      console.log("-> :", this.id);
    }

  8. #8
    Membre expérimenté
    Homme Profil pro
    bricoleur par les mots
    Inscrit en
    Avril 2015
    Messages
    714
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 79
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : bricoleur par les mots
    Secteur : Distribution

    Informations forums :
    Inscription : Avril 2015
    Messages : 714
    Points : 1 598
    Points
    1 598
    Par défaut
    jour

    si c'est l'id du parent qui est recherche la syntaxe est

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ev.currentTarget.parentNode.id
    Plus vite encore plus vite toujours plus vite.

  9. #9
    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 637
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    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 637
    Points : 66 661
    Points
    66 661
    Billets dans le blog
    1
    Par défaut
    le click se propage des enfants aux parents ...
    tu peux boucler sur les parents de l'élément clické jusqu'à trouver un élément de class "btn" par exemple et récupérer son id
    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 !

  10. #10
    Modérateur

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

    Informations forums :
    Inscription : Janvier 2011
    Messages : 16 959
    Points : 44 122
    Points
    44 122
    Par défaut
    Citation Envoyé par NoSmoking
    Tu n'auras pas forcément le résultat escompté avec ev.currentTarget.id.
    je n'ai pas retrouvé le cas où cela c'était produit ...

    Donc autant utiliser currentTarget qui présente l'avantage de bien récupérer l'élément déclencheur lors de l'utilisation d'une « arrow function », alors que this est le contexte d'exécution.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    const oDiv = document.querySelector("div");
    oDiv.addEventListener("click", (e) => {
      console.log("(1)", this.tagName);
      console.log("(2)", e.currentTarget.tagName);
    });
    //>> (1) undefined
    //>> (2) DIV
    alors que
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    const oDiv = document.querySelector("div");
    oDiv.addEventListener("click", function (e) {
      console.log("(1)", this.tagName);
      console.log("(2)", e.currentTarget.tagName);
    });
    //>> (1) DIV
    //>> (1) DIV

  11. #11
    Futur Membre du Club
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2007
    Messages : 12
    Points : 7
    Points
    7
    Par défaut Ma première idée
    Citation Envoyé par SpaceFrog Voir le message
    le click se propage des enfants aux parents ...
    tu peux boucler sur les parents de l'élément clické jusqu'à trouver un élément de class "btn" par exemple et récupérer son id
    Bonjour, effectivement, je pensais à une solution de ce type au départ, mais currenTarget est parfait dans mon cas

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

Discussions similaires

  1. [Dojo] Ecouter un event "onclick" sur un bouton avec Dojo 1.7
    Par andlio dans le forum Bibliothèques & Frameworks
    Réponses: 2
    Dernier message: 28/12/2011, 01h51
  2. onclick sur un bouton radio : image apparait
    Par isa150183 dans le forum jQuery
    Réponses: 4
    Dernier message: 25/03/2011, 10h52
  3. Réponses: 13
    Dernier message: 03/09/2010, 10h27
  4. Réponses: 23
    Dernier message: 16/03/2010, 15h19
  5. OnClick sur un bouton créé dynamiquement
    Par Jeankiki dans le forum Delphi
    Réponses: 4
    Dernier message: 05/11/2006, 18h44

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