我不能把头绕着这件事。似乎很容易。
<ul class="steps anchor">
<li><a href="#step-1" class="done" isdone="1" rel="1"><label class="stepNumber">1</label></a></li>
<li><a href="#step-2" class="disabled" isdone="0" rel="2"><label class="stepNumber">2</label></a></li>
<li><a href="#step-3" class="selected" isdone="1" rel="3"><label class="stepNumber">3</label></a></li>
<li><a href="#step-4" class="disabled" isdone="0" rel="4"><label class="stepNumber">4</label></a></li>
</ul>
我想要的是:我想选择当前的Li (class="selected") (=3),然后想要得到上一个LI的rel,它有class=“完成”。
$('ul.steps li a.selected').prev('li').hasClass('done').html() )
我被困在这条路上了。也许有人能帮我找到正确的方向?谢谢
编辑:我说李和class=“完成”了。但这必须是:我想要的是:我想选择当前的a (class="selected") (=3),然后想要得到具有class=“完成”的前一个a的rel。
Edit2:
我更新了我的李结构。现在假设我在李六号,我想带着aclass=‘to’去上一个李。所以arel=3,你的分析器总是把第一个LI还给(1)。
发布于 2012-10-18 10:04:49
如果要以这种方式选择无效的元素,可以使用prevAll
all方法:
$('a.selected').parent().prevAll('li:has("a.done")').find('a').attr('rel');
http://jsfiddle.net/pn72t/
或者:
$('a.selected').closest('ul').find("a.done:first").attr('rel')
发布于 2012-10-18 10:06:20
$('ul.steps li a.selected').closest("ul").find("a.done").attr('rel')
见小提琴:http://jsfiddle.net/CnkNX/1/
发布于 2012-10-18 09:59:14
您可以使用get
方法从'a.done`‘检索任何元素
$($('a.selected').closest('ul').find("li a.done").get(0)).attr('rel')
小提琴手:http://jsfiddle.net/gpznn/2/
https://stackoverflow.com/questions/12951919
复制相似问题