Accéder a un élément d'une même division

Résolu
Hamster18 Messages postés 176 Date d'inscription   Statut Membre Dernière intervention   -  
Hamster18 Messages postés 176 Date d'inscription   Statut Membre Dernière intervention   -
Bonjour,
j'ai une aborescence html comme suit :

<div class="div">
 <h2>News 3</h2>
 <p class="text">bloblob1</p>
 <p><a class="btn" href="#" role="button">View</a></p>
</div>
<div class="div">
 <h2>News 3</h2>
 <p class="text">bloblob2</p>
 <p><a class="btn" href="#" role="button">View</a></p>
</div>

j'aimerai que lorsque j’appuie sur le bouton je puisses récupérer la valeur du texte.
auriez vous des proposition a me proposer ?
Cordialement.

EDIT : Correction des balises de code

2 réponses

jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752
 
Bonjour,

Le text se trouvant dans un élément qui se trouve "avant" tu peux essayer d'utiliser le selecteur prev
https://api.jquery.com/prev/
Mais comme le bouton est contenu dans une balise <p> il faut, au préalable faire appel au selecteur parent
https://api.jquery.com/parent/

Donc un truc du genre
var pText = $(this).parent().prev();
var txt = pText.html();

0
Hamster18 Messages postés 176 Date d'inscription   Statut Membre Dernière intervention  
 
D'accord est auriez vous une idée de comment gérer le faut qu'il y ai plusieurs boutons ?
0
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752 > Hamster18 Messages postés 176 Date d'inscription   Statut Membre Dernière intervention  
 
Le dollar this correspond au bouton sur lequel tu as cliqué
0
Hamster18 Messages postés 176 Date d'inscription   Statut Membre Dernière intervention   > jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention  
 
a quel endroit car comme ceci :
document.querySelectorAll(".btn-secondary").forEach( input => input.addEventListener('click', clickViewDetail($this)) );

Cela me provoque une erreur : ReferenceError: $this is not defined
0
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752 > Hamster18 Messages postés 176 Date d'inscription   Statut Membre Dernière intervention  
 
Si tu as lu les liens que je t'ai donné tu as dû voir que ça faisait référence à jQuery


Si tu tiens à le faire en pure JavaScript dans ce cas-là la syntaxe est un peu différente

Par exemple pour avoir le parent

var child1 = document.getElementById("child1"),
    parent = child1.parentNode,
    
0
Hamster18 Messages postés 176 Date d'inscription   Statut Membre Dernière intervention  
 
Oui j'ai vu, mais votre réponse ma guider. Mais cela ne m'aide pas pour ma seconde question ?
0
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752
 
0
Hamster18 Messages postés 176 Date d'inscription   Statut Membre Dernière intervention   > jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention  
 
Merci beaucoup !!
0