jQuery find closest parent link with attribute

淺唱寂寞╮ 提交于 2019-11-30 04:43:45

问题


I'd like to find the closest link with attribute findme from a children .startpoint. Structure:

<ul>
    <li><a href="#">Point one</a></li>
    <li><a href="#" data-findme="yipi">Point one</a>
        <ul>
            <li><a href="#">Hello</a></li>
            <li><a href="#">Hello</a>
                <ul>
                    <li><a href="#" class="startpoint">My Startpoint</a></li>
                </ul>
            </li>
        </ul>
    </li>
</ul>

JavaScript (jQuery):

$(document).ready(function(){
    console.log(
        $('.startpoint').closest("*[data-findme]")
    );
});

Since the problem is, that the element data-findme is not a a parent element instead it is another child of a parent, my example will not find the element. The example: http://jsfiddle.net/rjhgvxoe/

How can I get it to work?


回答1:


You would need a selector like this:

$('.startpoint').closest("li:has(*[data-findme])")

That would query for the closest <li> element which contains an element with the attribute data-findme. To grab the anchor from there

$('.startpoint').closest("li:has(*[data-findme])").children('[data-findme]')



回答2:


You need to use:

 $('.startpoint').closest("ul").find('[data-findme]')

Demo



来源:https://stackoverflow.com/questions/27984795/jquery-find-closest-parent-link-with-attribute

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!