Jquery ne pas sélectionner l'arbre traversant
-
27-10-2019 - |
Question
J'ai quelques variables jquery qui tentent d'obtenir des valeurs d'éléments à proximité mais ils ne fonctionnent pas. Je pensais que le plus proche () est le sélecteur droit.
JQUERY:
$(".answerContainer").on("click", ".editAnswer", function(e){
e.preventDefault();
var answer_id = $(this).closest('.answer_id').attr('value'); //this doenst work
HTML:
<p name='singleAnswer' class='singleAnswer'>$answer[$f]</p>
<input type='hidden' value='$answerid[$f]' class='answer_id' />
<p class='ratingBox'> $answerrating[$f]</p>
<div class='answerBar'>";
<a href='#' class='upVote vote'>Upvote</a> · <a href='#' class='downVote vote'>Downvote</a> ·
<a class='answerTime'> $difference $periods[$j] ago</a>
· <a href='#' style='color: orange;' class='editAnswer'><b>Edit</b></a>
La solution
Essayez cela, utilisez également .val()
au lieu de attr('value')
var answer_id = $('.editAnswer').parent().siblings('.answer_id').val();
Autres conseils
le plus proche suppose que vous voulez parcourir à travers les ancêtres du nœud. Dans ce cas, essayez prev ()
$('.editAnswer').parent().find('.answer_id').val('value');
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow