大家好,我不明白如何将“div”设为“li”元素 我有水平列表,我需要动画我的箭头点击元素。
<ul class="tabs-titles">
<li><a href="#tab-1">best <br/> gifts</a></li>
<li><a href="#tab-2">best <br/> gifts</a></li>
<li><a href="#tab-3">best <br/> for gifts</a></li>
<li><a href="#tab-4">best <br/> gifts</a></li>
<li><a href="#tab-5">best <br/> gifts</a></li>
<li><a href="#tab-6">best <br/> gifts <br/> gifts</a></li>
</ul>
<div class="active-tab"></div>
这是我的fiddle。
答案 0 :(得分:2)
这很有效。看看我的编辑。
您必须使用$(this).position().top + $(this).height()/2
代替parent.height()
来移动箭头。
玩得开心!
答案 1 :(得分:0)
我看到@Kevin发布了一个非常好的答案,我建议你使用他的,但是,为了完整性,我会发布另一种方法。请注意,它并不完美,需要进行一些微调以适应任何最终情况,但它会起作用。
这将完成工作:
通过使用基本高度和选项卡的编号,您可以确定每个链接的正确高度。您唯一需要注意的是:
var dist = 22 + (num-1)*($(this).height()+(parseInt($(this).css("marginTop"))*2));
这要求所有链接都具有相同的高度。如果您希望任何链接具有不同的高度,则需要使用不同的方法来计算距离div顶部的距离。