• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Tabs nie działa poprawnie

Object Storage Arubacloud
+1 głos
123 wizyt
pytanie zadane 9 czerwca 2021 w HTML i CSS przez Nearr Obywatel (1,890 p.)

Cały kod: https://codepen.io/Nearr2020/pen/vYxzOaJ

Jak widać po kliknięciu na "NA" albo "AS" nie widać ich zawartości.

Dzieje się to tylko gdy dodam ten kod: 

    <div class="xezz-server-list">
                <div class="server-name">FFA 1</div>
                <div class="players-area">
                  <div class="players-counter">10 / 70</div>
                </div>
              </div>

              <div class="xezz-server-list">
                <div class="server-name">FFA 2</div>
                <div class="players-area">
                  <div class="players-counter">10 / 70</div>
                </div>
              </div>
        
              <div class="parting-modes"></div>
        
              <div class="xezz-server-list">
                <div class="server-name">Instant 1</div>
                <div class="players-area">
                  <div class="players-counter">10 / 70</div>
                </div>
              </div>
        
              <div class="xezz-server-list">
                <div class="server-name">Instant 2</div>
                <div class="players-area">
                  <div class="players-counter">10 / 70</div>
                </div>
              </div>
        
              <div class="parting-modes"></div>
        
              <div class="xezz-server-list">
                <div class="server-name">Gigasplit 1</div>
                <div class="players-area">
                  <div class="players-counter">10 / 70</div>
                </div>
              </div>
        
              <div class="xezz-server-list">
                <div class="server-name">Gigasplit 2</div>
                <div class="players-area">
                  <div class="players-counter">10 / 70</div>
                </div>
              </div>
        
              <div class="xezz-server-list">
                <div class="server-name">Gigasplit 3</div>
                <div class="players-area">
                  <div class="players-counter">10 / 70</div>
                </div>
              </div>
        
              <div class="xezz-server-list">
                <div class="server-name">Gigasplit 4</div>
                <div class="players-area">
                  <div class="players-counter">10 / 70</div>
                </div>
              </div>
        
              <div class="parting-modes"></div>
        
              <div class="xezz-server-list">
                <div class="server-name">Megasplit 1</div>
                <div class="players-area">
                  <div class="players-counter">10 / 70</div>
                </div>
              </div>
        
              <div class="parting-modes"></div>
        
              <div class="xezz-server-list">
                <div class="server-name">Self-Feed 1</div>
                <div class="players-area">
                  <div class="players-counter">10 / 70</div>
                </div>
              </div>
        
              <div class="xezz-server-list">
                <div class="server-name">Self-Feed 2</div>
                <div class="players-area">
                  <div class="players-counter">10 / 70</div>
                </div>
              </div>
        
              <div class="xezz-server-list">
                <div class="server-name">Self-Feed 3</div>
                <div class="players-area">
                  <div class="players-counter">10 / 70</div>
                </div>
              </div>
        
              <div class="xezz-server-list">
                <div class="server-name">Self-Feed 4</div>
                <div class="players-area">
                  <div class="players-counter">10 / 70</div>
                </div>
              </div>
        
              <div class="xezz-server-list">
                <div class="server-name">Self-Feed 5</div>
                <div class="players-area">
                  <div class="players-counter">10 / 70</div>
                </div>
              </div>
        
              <div class="xezz-server-list">
                <div class="server-name">Self-Feed 6</div>
                <div class="players-area">
                  <div class="players-counter">10 / 70</div>
                </div>
              </div>
            </div>

            <div class="na-content">
              <div class="xezz-server-list">
                <div class="server-name">FFA 1</div>
                <div class="players-area">
                  <div class="players-counter">10 / 70</div>
                </div>
              </div>
        
              <div class="parting-modes"></div>
        
              <div class="xezz-server-list">
                <div class="server-name">Gigasplit 1</div>
                <div class="players-area">
                  <div class="players-counter">10 / 70</div>
                </div>
              </div>
        
              <div class="parting-modes"></div>
        
              <div class="xezz-server-list">
                <div class="server-name">Megasplit 1</div>
                <div class="players-area">
                  <div class="players-counter">10 / 70</div>
                </div>
              </div>
        
              <div class="parting-modes"></div>
        
              <div class="xezz-server-list">
                <div class="server-name">Self-Feed 1</div>
                <div class="players-area">
                  <div class="players-counter">10 / 70</div>
                </div>
              </div>
        
              <div class="xezz-server-list">
                <div class="server-name">Self-Feed 2</div>
                <div class="players-area">
                  <div class="players-counter">10 / 70</div>
                </div>
              </div>
        
              <div class="xezz-server-list">
                <div class="server-name">Self-Feed 3</div>
                <div class="players-area">
                  <div class="players-counter">10 / 70</div>
                </div>
              </div>
              <div class="parting-modes"></div>

 

2 odpowiedzi

+1 głos
odpowiedź 10 czerwca 2021 przez VBService Ekspert (252,660 p.)
wybrane 10 czerwca 2021 przez Nearr
 
Najlepsza

Tak jak już @pablop76 napisał

Myślę, że zbyt ogólnikowo pobierasz elementy. 

 

Propozycja

<div class="tabs">
  <div class="tab-header">
    <div class="tab active">
      EU
    </div>
    <div class="tab">
      NA
    </div>
    <div class="tab">
      AS
    </div>
  </div>
  <div class="content-wrapper">

    <div class="content active">
      <div class="xezz-server-list">
        <div class="server-name">FFA 1</div>
        <div class="players-area">
          <div class="players-counter">10 / 70</div>
        </div>
      </div>

      <div class="xezz-server-list">
        <div class="server-name">FFA 2</div>
        <div class="players-area">
          <div class="players-counter">10 / 70</div>
        </div>
      </div>

      <div class="parting-modes"></div>

      <div class="xezz-server-list">
        <div class="server-name">Instant 1</div>
        <div class="players-area">
          <div class="players-counter">10 / 70</div>
        </div>
      </div>

      <div class="xezz-server-list">
        <div class="server-name">Instant 2</div>
        <div class="players-area">
          <div class="players-counter">10 / 70</div>
        </div>
      </div>

      <div class="parting-modes"></div>

      <div class="xezz-server-list">
        <div class="server-name">Gigasplit 1</div>
        <div class="players-area">
          <div class="players-counter">10 / 70</div>
        </div>
      </div>

      <div class="xezz-server-list">
        <div class="server-name">Gigasplit 2</div>
        <div class="players-area">
          <div class="players-counter">10 / 70</div>
        </div>
      </div>

      <div class="xezz-server-list">
        <div class="server-name">Gigasplit 3</div>
        <div class="players-area">
          <div class="players-counter">10 / 70</div>
        </div>
      </div>

      <div class="xezz-server-list">
        <div class="server-name">Gigasplit 4</div>
        <div class="players-area">
          <div class="players-counter">10 / 70</div>
        </div>
      </div>

      <div class="parting-modes"></div>

      <div class="xezz-server-list">
        <div class="server-name">Megasplit 1</div>
        <div class="players-area">
          <div class="players-counter">10 / 70</div>
        </div>
      </div>

      <div class="parting-modes"></div>

      <div class="xezz-server-list">
        <div class="server-name">Self-Feed 1</div>
        <div class="players-area">
          <div class="players-counter">10 / 70</div>
        </div>
      </div>

      <div class="xezz-server-list">
        <div class="server-name">Self-Feed 2</div>
        <div class="players-area">
          <div class="players-counter">10 / 70</div>
        </div>
      </div>

      <div class="xezz-server-list">
        <div class="server-name">Self-Feed 3</div>
        <div class="players-area">
          <div class="players-counter">10 / 70</div>
        </div>
      </div>

      <div class="xezz-server-list">
        <div class="server-name">Self-Feed 4</div>
        <div class="players-area">
          <div class="players-counter">10 / 70</div>
        </div>
      </div>

      <div class="xezz-server-list">
        <div class="server-name">Self-Feed 5</div>
        <div class="players-area">
          <div class="players-counter">10 / 70</div>
        </div>
      </div>

      <div class="xezz-server-list">
        <div class="server-name">Self-Feed 6</div>
        <div class="players-area">
          <div class="players-counter">10 / 70</div>
        </div>
      </div>
    </div>

    <div class="content">
      NA lorem
    </div>

    <div class="content">
      AS lorem
    </div>

  </div>
</div>
.tabs {
  width: 345px;
  height: 500px;
  background: rgb(19, 19, 19);
  overflow: hidden;
  border-radius: 5px;
}
   
.tabs .tab-header {
  display: flex;
  align-items: center;
}
   
.tabs .tab-header .tab {
  width: 121px;
  text-align: center;
  color: #919191;
  background: rgb(15, 15, 15);
  font-family: 'Ubuntu', sans-serif;
  height: 35px;
  cursor: pointer;
  font-size: 14px;
  text-transform: uppercase;
  outline: none;
  user-select: none; /* dodane */
  display: flex;
  justify-content: center;
  align-items: center;
  border-top: 2px solid #00477e;
}
   
.as-btn {
  margin-top: -5px;
  border-right: 2px solid #00477e;
}
   
   
.tabs .tab-header .tab:hover:not(.active) {
  color: #bebebe;
  background: #161616;
  transition: background 0.4s;
}
   
.tabs .tab-header .active {
  color: #ffffff;
  background: #131313;
  transition: 0.1s;
}
.tabs .tab-header .active:hover {
  cursor: default;
}
   
.tabs .content-wrapper {
  position: relative;
  height: 480px;
}
   
.tabs .content-wrapper .content {
  position: absolute;
  opacity: 0;
  letter-spacing: 1em; /*  :-)  */
  transition: all 0.45s ease-out; /*  :-)  */
}
   
.tabs .content-wrapper .active {
  letter-spacing: 0; /*  :-)  */
  opacity: 1;
}
   
   
/* dodane do testów */
.tabs .content-wrapper .content {
  color: white;
}
const         tabs = document.querySelectorAll('.tab-header .tab');
const tabs_content = document.querySelectorAll('.content-wrapper .content');

tabs.forEach((tab, index) => {
  tab.addEventListener('click', () => {
    if (! tabs[index].classList.contains('active')) {
              tabs.forEach(tab => { tab.classList.remove('active'); });
      tabs_content.forEach(tab => { tab.classList.remove('active'); });

              tabs[index].classList.add('active');
      tabs_content[index].classList.add('active');     
    }
  })
});

 

1
komentarz 10 czerwca 2021 przez Nearr Obywatel (1,890 p.)
Dziękuje :)
+3 głosów
odpowiedź 10 czerwca 2021 przez pablop76 VIP (123,120 p.)

Zwróć uwagę co zwraca Ci 

tabBody.getElementsByTagName("div")[i]

Myślę, że zbyt ogólnikowo pobierasz elementy. 

let tabsPane = tabHeader.getElementsByTagName("div");

 

1
komentarz 10 czerwca 2021 przez Nearr Obywatel (1,890 p.)
Również dziękuję za zwrócenie mi uwagi :)

Podobne pytania

0 głosów
0 odpowiedzi 134 wizyt
pytanie zadane 29 października 2017 w HTML i CSS przez Ziuziek Mądrala (5,140 p.)
0 głosów
1 odpowiedź 99 wizyt
pytanie zadane 30 kwietnia 2017 w HTML i CSS przez zed Nowicjusz (230 p.)
0 głosów
2 odpowiedzi 452 wizyt
pytanie zadane 11 lutego 2016 w HTML i CSS przez MatiiTv Gaduła (3,790 p.)

92,539 zapytań

141,382 odpowiedzi

319,480 komentarzy

61,928 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...