我正在尝试获取一些“上一个”和“下一个”按钮,以逐步浏览“ Bootstrap”选项卡窗格。
我读过一些似乎很接近的文章,但准确不是我想要的。
其他示例似乎正在寻找active
导航标签,但是下一个和上一个按钮位于单独的标签容器中,因此我试图使它们独立于导航容器中,因此该方法实际上不起作用。
到目前为止,我一直在使用.next()
将active
和show
类添加到选项卡窗格,但似乎将它们添加到所有选项卡窗格中,而不仅仅是一个单独。因此,如果我走对了路,或者有更简单的方法可以做到这一点,我不是100%?好像有,我可能只是对自己感到困难。
无论如何,这是我到目前为止所拥有的...
Codepen链接: https://codepen.io/ultraloveninja/pen/OBjmzy/
HTML:
<div class="container">
<!-- Nav tabs -->
<ul id="mytabs" class="nav nav-tabs" role="tablist">
<li class="active">
<a href="#first" role="tab" data-toggle="tab">
<icon class="fa fa-home"></icon> First tab
</a>
</li>
<li><a href="#second" role="tab" data-toggle="tab">
<i class="fa fa-user"></i> Second tab
</a>
</li>
<li>
<a href="#third" role="tab" data-toggle="tab">
<i class="fa fa-envelope"></i> Third tab
</a>
</li>
</ul>
<!-- Tab panes -->
<div class="tab-content">
<div class="tab-pane fade active in" id="first">
<h2>First tab</h2>
</div>
<div class="tab-pane fade" id="second">
<h2>Second tab</h2>
</div>
<div class="tab-pane fade" id="third">
<h2>Third tab</h2>
</div>
</div>
<a class="btn prev" href="#">Previous</a>
<a class="btn next" href="#">Next</a>
</div>
JS:
$(function(){
$('#mytabs a:first').tab('show');
$('.next').on("click",function(e){
var $this = $(this);
if($(".tab-pane").hasClass("active")) {
$('.tab-pane').next().addClass('show active');
$this.prev().removeClass('show active');
e.preventDefault();
}
});
});
我认为,如果我可以分步进行下一步,那么我可以修改前一个步骤。
答案 0 :(得分:0)
确定并询问后确定,我发现了:
$(".next").on("click", function(e) {
const $active = $(".tab-pane.active");
const $next = $active.next();
if ($next.length) {
$active.removeClass("active show");
$next.addClass("active show");
}
e.preventDefault();
});
$(".prev").on("click", function(e) {
const $active = $(".tab-pane.active");
const $prev = $active.prev();
if ($prev.length) {
$active.removeClass("active show");
$prev.addClass("active show");
}
e.preventDefault();
});
最大的事情是,您需要确保div的上一步和下一步按钮位于外部,而该div包含选项卡窗格。否则,它将继续走下去。
这是一支未经修饰的笔,可以用来说明我要实现的目标: