jQuery: получить родитель, идентификатор родителя?


<ul id ="myList">
<li><a href="www.example.com">link</a></li>
</ul>

Как я могу получить идентификатор ul (myList) с помощью jQuery? Моей J-скрипт событие инициируется, когда пользователь щелкает ссылку. Я пробовал:

$(this).parent().attr('id');

но он получает идентификатор li, мне нужно пойти на один выше, и я не могу прикрепить щелчок к li либо.

3 56

3 ответа:

$(this).parent().parent().attr('id');

Как вы получите идентификатор родителя родителя.

EDIT:

$(this).closest('ul').attr('id');

является более надежным решением для вашего случая.

 $(this).closest('ul').attr('id');

вот 3 примера:

$(document).on('click', 'ul li a', function (e) {
    e.preventDefault();

    var example1 = $(this).parents('ul:first').attr('id');
    $('#results').append('<p>Result from example 1: <strong>' + example1 + '</strong></p>');

    var example2 = $(this).parents('ul:eq(0)').attr('id');
    $('#results').append('<p>Result from example 2: <strong>' + example2 + '</strong></p>');
  
    var example3 = $(this).closest('ul').attr('id');
    $('#results').append('<p>Result from example 3: <strong>' + example3 + '</strong></p>');
  
  
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<ul id ="myList">
  <li><a href="www.example.com">Click here</a></li>
</ul>

<div id="results">
  <h1>Results:</h1>
</div>

Дайте мне знать, было ли это полезно.