我做了一个快速的 jsFiddle 来展示我遇到的问题:
JavaScript(主要来自Multipart Form - jQuery)
$('.step1').siblings('ul').hide(); // hide all except step 1
$('.continue').click(function(){
$(this).closest('.step').hide("slide", direction:"left"},1500).parent().next('.step').show("slide",{direction:"right"},1500);
return false;
});
$('.back').click(function(){
$(this).closest('.step').slideUp().prev('.step').slideDown();
return false;
});
HTML
Non-Floater
<form class="a">
<ul class="step step1">
<li>item</li>
<li>item</li>
<li>
<button class="continue">Continue</button>
</li>
</ul>
<ul class="step step2">
<li>item</li>
<li>item</li>
<li>
<button class="back">Back</button>
<button class="continue">Continue</button>
</li>
</ul>
</form>
Floater
<form class="floater">
<ul class="step step1">
<li>item</li>
<li>item</li>
<li>
<button class="continue">Continue</button>
</li>
</ul>
<ul class="step step2">
<li>item</li>
<li>item</li>
<li>
<button class="back">Back</button>
<button class="continue">Continue</button>
</li>
</ul>
</form>
CSS
ul {
margin: 0;
padding: 0;
list-style-type: none;
}
.floater ul {
width: 30%;
float: left;
}
当您单击“继续”时,第二个 UL 进入,但它偏移低于当前 UL。理想情况下,这将直接进入第一个 UL 的右侧。
添加“float:left;width:30%”会有所帮助,但它仍然会跳来跳去。(jsFiddle上的第二个)
显示:内联似乎也会引起怪异......
知道如何做到这一点吗?