我尝试找到当前元素的next或prev元素。但是next()和prev()函数只能在一个范围内工作,它不能到达外部。例如,这是我想要实现的:
<ul id="ul1"> <li>1</li> <li>2</li> <li>3</li> <li> <ul id="ul2"> <li>4</li> <li> <ul id="ul3"> <li>5</li> <li>6</li> </ul> </li> <li>7</li> <li>8</li> </ul> </li> <li>9</li> </ul>
如果当前元素为ul1,则next元素为< li> 1< / li>,prev元素为null。
如果当前元素为< li> 1< / li>,则下一个元素为< li> 2< / li>,prev元素为ul1
如果当前元素为< li> 8< / li>,则下一个元素为< li> 9< / li>,prev元素为< li> 7< / li>
解决方法
首先,这是一个非常整洁的问题。感谢发帖!
我用一个链接的jQuery语句完成了这个。只有事情是,如果你运行上面的()顶部ul你会得到身体。我认为技术上有道理。但是,如果这不是所需的行为,请参阅下面的更新。
用法:next(“#ul3”)返回< li> 5< / li>
下一个:
function next(selector) { var $element = $(selector); return $element .children(":eq(0)") .add($element.next()) .add($element.parents().filter(function() { return $(this).next().length > 0; }).next()).first(); }
以前:
function prevIoUs(selector) { var $element = $(selector); return $element .prev().find("*:last") .add($element.parent()) .add($element.prev()) .last(); }
更新如果要限制以前最上方的节点可以,可以做:
function prevIoUs(selector,root) { var $element = $(selector); return $element .prev().find("*:last") .add($element.parent()) .add($element.prev()) .last().not($(root).parent()); }
http://jsfiddle.net/andrewwhitaker/n89dz/
(function($) { $.fn.domNext = function() { return this .children(":eq(0)") .add(this.next()) .add(this.parents().filter(function() { return $(this).next().length > 0; }).next()).first(); }; $.fn.domPrevIoUs = function() { return this .prev().find("*:last") .add(this.parent()) .add(this.prev()) .last(); }; })(jQuery);
原文地址:https://www.jb51.cc/jquery/181940.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。