Maison > interface Web > Questions et réponses frontales > Comment écrire des onglets en javascript

Comment écrire des onglets en javascript

PHPz
Libérer: 2023-04-25 16:44:08
original
854 Les gens l'ont consulté

Avec le développement d'Internet, les interfaces des sites Web sont devenues de plus en plus cool et les onglets sont devenus l'un des éléments d'interface utilisateur courants des sites Web modernes. Cet article explique comment utiliser JavaScript pour écrire des onglets afin de rendre votre site Web plus moderne.

  1. Structure HTML

Tout d'abord, nous devons créer la structure d'onglets en HTML. Vous pouvez utiliser le code suivant :

<div class="tab-container">
  <ul class="tab-nav">
    <li class="tab-nav-item active">Tab 1</li>
    <li class="tab-nav-item">Tab 2</li>
    <li class="tab-nav-item">Tab 3</li>
  </ul>
  <div class="tab-content active">Tab 1 content</div>
  <div class="tab-content">Tab 2 content</div>
  <div class="tab-content">Tab 3 content</div>
</div>
Copier après la connexion

La structure HTML ci-dessus contient un conteneur d'onglets (tab-container), qui contient une option Navigation par carte. barre (onglet-nav) et contenu de l'onglet (onglet-contenu). Dans une barre de navigation, chaque onglet est un élément de liste (tab-nav-item), et l'onglet actuellement sélectionné peut être indiqué en ajoutant une classe « active ». Dans le contenu, vous pouvez également indiquer le contenu de l'onglet actuellement sélectionné en ajoutant la classe "active".

  1. Style CSS

Ensuite, nous devons ajouter des styles aux onglets et au contenu. Vous pouvez utiliser le code suivant :

.tab-container {
  display: flex;
  flex-direction: column;
  margin: 20px;
  border: 1px solid #ccc;
  border-radius: 4px;
  overflow: hidden;
  box-shadow: rgba(0, 0, 0, 0.2) 0px 2px 6px;
}

.tab-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #eee;
  padding: 10px;
}

.tab-nav-item {
  cursor: pointer;
  padding: 10px;
  border-radius: 4px;
  transition: all 0.3s ease;
}

.tab-nav-item:hover {
  background: #fff;
}

.tab-nav-item.active {
  background: #fff;
  font-weight: bold;
}

.tab-content {
  padding: 20px;
  display: none;
}

.tab-content.active {
  display: block;
}
Copier après la connexion

Le style CSS ci-dessus définit l'emplacement, la taille, la bordure, l'ombre et d'autres propriétés de l'onglet. conteneur et styles pour le contenu de la barre de navigation et des onglets. Notez que la propriété d'affichage du contenu de l'onglet est définie sur none, qui ne sera affichée que lorsque l'onglet correspondant est sélectionné.

  1. Code JavaScript

Enfin, nous devons écrire du code JavaScript pour que le commutateur d'onglet s'affiche au clic. Vous pouvez utiliser le code suivant :

const tabs = document.querySelectorAll('.tab-nav-item');
const contents = document.querySelectorAll('.tab-content');

for (let i = 0; i < tabs.length; i++) {
  tabs[i].addEventListener(&#39;click&#39;, function() {
    // 首先隐藏所有选项卡内容
    for (let j = 0; j < contents.length; j++) {
      contents[j].classList.remove(&#39;active&#39;);
    }
    // 设置当前选中的选项卡添加 "active" 类
    for (let j = 0; j < tabs.length; j++) {
      tabs[j].classList.remove(&#39;active&#39;);
    }
    this.classList.add(&#39;active&#39;);
    contents[i].classList.add(&#39;active&#39;);
  });
}
Copier après la connexion

Le code JavaScript ci-dessus utilise un écouteur d'événement pour implémenter la fonction de changement du contenu de l'onglet correspondant lorsque vous cliquez sur la barre de navigation de l'onglet. Tout d'abord, masquez tout le contenu de l'onglet, puis définissez l'onglet actuellement sélectionné et le contenu correspondant pour ajouter la classe « active » afin d'obtenir l'effet d'afficher le contenu de l'onglet.

  1. Code complet

Enfin, nous combinons les codes HTML, CSS et JavaScript ci-dessus pour former le code complet comme suit :

<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <title>Tab 选项卡</title>
  <style>
    .tab-container {
      display: flex;
      flex-direction: column;
      margin: 20px;
      border: 1px solid #ccc;
      border-radius: 4px;
      overflow: hidden;
      box-shadow: rgba(0, 0, 0, 0.2) 0px 2px 6px;
    }

    .tab-nav {
      display: flex;
      justify-content: space-between;
      align-items: center;
      background: #eee;
      padding: 10px;
    }

    .tab-nav-item {
      cursor: pointer;
      padding: 10px;
      border-radius: 4px;
      transition: all 0.3s ease;
    }

    .tab-nav-item:hover {
      background: #fff;
    }

    .tab-nav-item.active {
      background: #fff;
      font-weight: bold;
    }

    .tab-content {
      padding: 20px;
      display: none;
    }

    .tab-content.active {
      display: block;
    }
  </style>
</head>
<body>
  <div class="tab-container">
    <ul class="tab-nav">
      <li class="tab-nav-item active">Tab 1</li>
      <li class="tab-nav-item">Tab 2</li>
      <li class="tab-nav-item">Tab 3</li>
    </ul>
    <div class="tab-content active">Tab 1 content</div>
    <div class="tab-content">Tab 2 content</div>
    <div class="tab-content">Tab 3 content</div>
  </div>

  <script>
    const tabs = document.querySelectorAll('.tab-nav-item');
    const contents = document.querySelectorAll('.tab-content');

    for (let i = 0; i < tabs.length; i++) {
      tabs[i].addEventListener(&#39;click&#39;, function() {
        // 首先隐藏所有选项卡内容
        for (let j = 0; j < contents.length; j++) {
          contents[j].classList.remove(&#39;active&#39;);
        }
        // 设置当前选中的选项卡添加 "active" 类
        for (let j = 0; j < tabs.length; j++) {
          tabs[j].classList.remove(&#39;active&#39;);
        }
        this.classList.add(&#39;active&#39;);
        contents[i].classList.add(&#39;active&#39;);
      });
    }
  </script>
</body>
</html>
Copier après la connexion

Maintenant, vous pouvez implémenter vous-même un onglet en copiant et collant le code ci-dessus, afin que votre le site Web est plus moderne.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal