12

我试图找到一个元素的父元素,它是父元素的第一个子元素,代码是这样的:

        <ul class="lowerMenu">
            <li><a href="" class="selected">Welcome</a></li>
            <li><a href="">Logo</a></li>
            <li><a href="">Websites</a></li>
            <li><a href="">Stationery</a></li>
            <li><a href="">Illustration</a></li>
            <li><a href="">Full Pack</a></li>
        </ul>

function setIntervalAndExecute() {
    changeImages();
    setTimeout(function(){
        showImages(imagesArray);
    },500);
    var intervalot = window.setInterval(function(){
        changeImages();
        var selected = $('.selected');
        if (!selected.parent().is(':last-child')) {
            $('.selected').parent().next().children().addClass('selected');
            selected.removeClass('selected');
        } else {
            $('.selected').parent().parent().children(':first-child').addClass('selected');
            selected.removeClass('selected'); // nesho ne mi rabotit ovdeki
        }
        window.setTimeout(function(){
            showImages(imagesArray);
        },500);
    },10000);
    return intervalot;
}
var intervalot = setIntervalAndExecute();

我知道这有点复杂,但我是 jquery 的新手,所以我想做的是在“selected”类到达最后一个元素之后,我想将其删除并将其设置为第一个元素。我已经尝试过了,但它似乎不起作用

$('.selected').parent().parent().children(':first-child').addClass('selected');

当它到达最后一个元素时,间隔执行两次然后停止。这是我正在处理的网站:

http://nikodola.com/testsite

4

4 回答 4

26

如果你上两层,然后找到下一个孩子,你只会下一层——你将selected班级设置在 上<li>,而不是在<a>它下面。你需要再下一层。所以应该是:

$('.selected').parent().parent().children(':first-child').children().addClass('selected');

到达那里的另一种方法是:

$('.selected').parent().siblings(':first-child').children().addClass('selected');
于 2013-08-30T11:06:03.827 回答
4
$('.selected').parent().siblings(':first-child').children().addClass('selected');

小提琴演示

于 2013-08-30T11:16:31.780 回答
-1
$('.selected').closest('ul').find('li:first').addClass('selected');

参考最接近

于 2013-08-30T11:08:38.660 回答
-1

不需要在层次结构中一个接一个地完全遍历到父级,您可以只使用parents()而不是parent()这种方式

$('.selected').parents('ul.lowerMenu').children(:first-child').addClass('selected');

试试看,这行得通!!

于 2013-08-30T11:09:34.623 回答