Выберите самого глубокого ребенка в jQuery - PullRequest
26 голосов
/ 24 сентября 2010

Есть ли дешевый метод выбора самого глубокого потомка элемента?

Пример:

<div id="SearchHere">
  <div>
    <div>
      <div></div>
    </div>
  </div>
  <div></div>
  <div>
    <div>
      <div>
        <div id="selectThis"></div>
      </div>
    </div>
  </div>
  <div>
    <div></div>
  </div>
</div>

Ответы [ 6 ]

29 голосов
/ 24 сентября 2010

РЕДАКТИРОВАТЬ: Это, вероятно, лучший подход, чем мой первоначальный ответ:

Пример: http://jsfiddle.net/patrick_dw/xN6d5/5/

var $target = $('#SearchHere').children(),
    $next = $target;

while( $next.length ) {
  $target = $next;
  $next = $next.children();
}

alert( $target.attr('id') );

или еще короче:

Пример: http://jsfiddle.net/patrick_dw/xN6d5/6/

var $target = $('#SearchHere').children();

while( $target.length ) {
  $target = $target.children();
}

alert( $target.end().attr('id') ); // You need .end() to get to the last matched set

Оригинальный ответ:

Казалось бы, это работает:

Пример: http://jsfiddle.net/xN6d5/4/

var levels = 0;
var deepest;

$('#SearchHere').find('*').each(function() {
    if( !this.firstChild || this.firstChild.nodeType !== 1  ) {
        var levelsFromThis = $(this).parentsUntil('#SearchHere').length;
        if(levelsFromThis > levels) {
            levels = levelsFromThis;
            deepest = this;
        }
    }
});

alert( deepest.id );

Если вы знаете, что самым глубоким будет определенный тег (или что-то еще), вы можете ускорить его, заменив, например, .find('*') на .find('div').

РЕДАКТИРОВАТЬ: Обновлен для проверки длины, только если текущий элемент не имеет firstChild или если он имеет, что firstChild не является узлом типа 1.

5 голосов
/ 19 февраля 2014

Вот небольшое улучшение ответа от @ user113716, эта версия обрабатывает случай, когда нет дочерних элементов, и возвращает саму цель.

 (function($) {

    $.fn.deepestChild = function() {
        if ($(this).children().length==0)
            return $(this);

        var $target = $(this).children(),
        $next = $target;

        while( $next.length ) {
          $target = $next;
          $next = $next.children();
        }

        return $target;
    };

}(jQuery));
3 голосов
/ 24 сентября 2010

Я не думаю, что вы можете сделать это напрямую, но вы можете попробовать

var s = "#SearchHere";
while($(s + " >div ").size() > 0)
    s += " > div";
alert( $(s).attr('id') );
1 голос
/ 24 января 2016

Этот цепной однострочный работал для меня, но он предполагает, что в иерархии ниже есть только один конечный узел.

jQuery("#searchBeginsHere")
  .filter(function(i,e){ return jQuery(e).children().size() === 0; })
0 голосов
/ 07 января 2019

Это найдет самый глубокий элемент типа "param" на странице.Полезно, если вы ищете самое глубокое или что-то еще.

function deepest_child(param) {
    var element_list = $(param)
    var depth = 0
    var deepest_element
    element_list.each(
        function (index) {
            this_depth = $(this).parents().length
            if (this_depth > depth) {
                depth = this_depth 
                deepest_element= $(this)
            }
        })  
    return deepest_element
}
0 голосов
/ 04 марта 2018

Версия для получения максимальной глубины для каждого листа.

http://jsfiddle.net/ncppk0zw/14/

var found = $('#SearchHere *');

for (var i = 0; i < found.length; i++) {
    if (i > 1) {
        if (found[i].parentNode !== found[i-1]) {
            // Deepest. Next element is other leaf
            console.log(found[i-1]);
            continue;
        }
        if (i == found.length-1) {
            // Deepest. Last element in DOM tree
            console.log(found[i]);
        }
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...