下一个和上一个按钮逐步浏览Bootstrap选项卡

时间:2018-10-12 15:21:56

标签: javascript jquery html twitter-bootstrap-3 bootstrap-tabs

我正在尝试获取一些“上一个”和“下一个”按钮,以逐步浏览“ Bootstrap”选项卡窗格。

我读过一些似乎很接近的文章,但准确不是我想要的。

其他示例似乎正在寻找active导航标签,但是下一个和上一个按钮位于单独的标签容器中,因此我试图使它们独立于导航容器中,因此该方法实际上不起作用。

到目前为止,我一直在使用.next()activeshow类添加到选项卡窗格,但似乎将它们添加到所有选项卡窗格中,而不仅仅是一个单独。因此,如果我走对了路,或者有更简单的方法可以做到这一点,我不是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();
    }
  });  
});

我认为,如果我可以分步进行下一步,那么我可以修改前一个步骤。

1 个答案:

答案 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包含选项卡窗格。否则,它将继续走下去。

这是一支未经修饰的笔,可以用来说明我要实现的目标:

https://codepen.io/ultraloveninja/pen/OBjmzy