AleksMey
@AleksMey
Пытаюсь разобраться

Как интегрировать табы в select?

Хочу сделать выбор табов через select, конструкция <option VALUE="#" data-tab="1">Скриншоты</option> не работает.

Есть форма select от Bootstrap

<select class="form-select form-select-sm" aria-label=".form-select-sm example" onchange="window.location.href=this.options[this.selectedIndex].value">
  <option selected>2022</option>
  <option VALUE="#" data-tab="1">Скриншоты</option>
  <option VALUE="#" data-tab="2">2024</option>
 
</select>


Есть сами табы

<div class="nav-tabs1">
  <a href="#" data-tab="1" class="nav-tab active">Скриншоты</a>
     <a href="#" data-tab="2" class="nav-tab">Видео</a> 

</div>
          
          <div class="tab-content ">
 <div data-tab-content="1" class="tab-pane active">
       <h5 class="fw-bold mb-3 my-1">Скриншоты</h5>
  Контент
  </div>
  <div data-tab-content="2" class="tab-pane">
      <h5 class="fw-bold mb-3 my-1">Видео</h5>
контент   
 
  </div>
</div>


Есть скрипт
var tabNavs = document.querySelectorAll(".nav-tab");
var tabPanes = document.querySelectorAll(".tab-pane");

for (var i = 0; i < tabNavs.length; i++) {

  tabNavs[i].addEventListener("click", function(e){
    e.preventDefault();
    var activeTabAttr = e.target.getAttribute("data-tab");

    for (var j = 0; j < tabNavs.length; j++) {
      var contentAttr = tabPanes[j].getAttribute("data-tab-content");

      if (activeTabAttr === contentAttr) {
        tabNavs[j].classList.add("active");
        tabPanes[j].classList.add("active"); 
      } else {
        tabNavs[j].classList.remove("active");
        tabPanes[j].classList.remove("active");
      }
    };
  });
}


Ну и стили

.nav-tabs1{
  display: flex;
                margin-bottom:-17px !important;
}
.nav-tab{
 
  margin-right: 20px;
  text-decoration: none;
}
.nav-tab.active{
    border-bottom: 3px solid #0d6efd;
    padding-bottom: 12px;
  cursor: default;       
    font-weight: 700 !important;
}

.tab-pane{
  display: none;
  
    
}
  • Вопрос задан
  • 138 просмотров
Пригласить эксперта
Ответы на вопрос 1
delphinpro
@delphinpro Куратор тега CSS
frontend developer
Зачем вот это вот всё:
tabNavs[j].classList.add("active");
tabPanes[j].classList.add("active");


Откройте уже документацию и переключайте табы правильно
https://getbootstrap.com/docs/5.1/components/navs-...
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы