Heim  >  Artikel  >  Web-Frontend  >  Vier Möglichkeiten, den Tab-Wechsel in Javascript zu implementieren

Vier Möglichkeiten, den Tab-Wechsel in Javascript zu implementieren

高洛峰
高洛峰Original
2017-02-08 16:48:381157Durchsuche

In diesem Artikel werden hauptsächlich vier Möglichkeiten zur Implementierung des Tab-Wechsels in JavaScript vorgestellt und jede Methode bewertet.

Tab-Wechsel ist auf Webseiten sehr verbreitet kürzlich.
Schreiben Sie zunächst den Tab-Rahmen und fügen Sie den einfachsten Stil hinzu. Der Code lautet wie folgt:

<!DOCTYPE html>
 <html>
 <head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<style>
 *{
 padding: 0;
 margin: 0;
 }
 li{
  list-style: none;
  float:left;
 }
 #tabCon{
  clear: both;
 }
 </style>
 </head>
 <body>
 <p id="tanContainer">
  <p id="tab">
  <ul>
   <li>标题一</li>
   <li>标题二</li>
   <li>标题三</li>
   <li>标题四</li>
  </ul>
  </p>
  <p id="tabCon">
  <p>内容一</p>
  <p>内容二</p>
  <p>内容三</p>
  <p>内容四</p>
  </p>
 </p>
 </body>
 </html>

Der aktuelle Anzeigeeffekt ist wie folgt Bild:

Vier Möglichkeiten, den Tab-Wechsel in Javascript zu implementieren

Die vier Registerkartentitel und vier Inhaltsbereiche werden auf der Seite angezeigt. Jetzt müssen wir den Tab-Umschalteffekt erzielen, dh auf Titel eins und klicken Der Inhalt wird nicht angezeigt. Klicken Sie auf Titel zwei, Inhalt zwei wird angezeigt und anderer Inhalt wird nicht angezeigt.
Dann ist die Gesamtidee sehr einfach: Binden Sie Ereignisse an vier Titel und wann Ausgelöst wird der entsprechende Inhalt angezeigt und andere Inhalte werden ausgeblendet.

Methode 1: Der Inhalt, der dem angeklickten Titel entspricht, wird angezeigt und der Inhalt, der dem nicht angeklickten Titel entspricht, wird ausgeblendet. Der Code lautet wie folgt:

 <!DOCTYPE html>
 <html>
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 <style>
 *{
  padding: 0;
  margin: 0;
 }
 li{
  list-style: none;
 }
 </style>
 <script>
 function tab(pid){
  var tabs=["tab1","tab2","tab3","tab4"];
  for(var i=0;i<4;i++){
   if(tabs[i]==pid){
    document.getElementById(tabs[i]).style.display="block";
  }else{
    document.getElementById(tabs[i]).style.display="none";
  }
  }
 }
 </script>
</head>
 <body>
 <p id="tanContainer">
  <p id="tabNav">
  <ul>
   <li onclick="tab(&#39;tab1&#39;)">标题一</li>
   <li onclick="tab(&#39;tab2&#39;)">标题二</li>
   <li onclick="tab(&#39;tab3&#39;)">标题三</li>
   <li onclick="tab(&#39;tab4&#39;)">标题四</li>
  </ul>
  </p>
  <p id="tab">
   <p id="tab1">内容一</p>
  <p id="tab2">内容二</p>
   <p id="tab3">内容三</p>
  <p id="tab4">内容四</p>
  </p>
 </p>
 </body>
 </html>

Methode 2: Zuerst alle Inhalte auf setzen ausgeblendet werden soll, klicken Sie dann auf Der Titel wird für den relevanten Inhalt angezeigt. Der Code lautet wie folgt:

 <!DOCTYPE html>
 <html>
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 <style>
 *{
  padding: 0;
  margin: 0;
 }
 li{
  list-style: none;
 float:left;
 }
 #tabCon{
  clear: both;
 }
 #tabCon_1{
 display: none;
 }
 #tabCon_2{
  display: none;
 }
 #tabCon_3{
 display: none;
 }
 </style>
 <script>
 function changeTab(tabCon_num){
 for(i=0;i<=3;i++) { 
  document.getElementById("tabCon_"+i).style.display="none"; //将所有的层都隐藏 
  } 
  document.getElementById("tabCon_"+tabCon_num).style.display="block";//显示当前层 
 } 
 </script>
 </head>
 <body>
 <p id="tanContainer">
  <p id="tab">
  <ul>
   <li onclick="changeTab(&#39;0&#39;)">标题一</li>
   <li onclick="changeTab(&#39;1&#39;)">标题二</li>
   <li onclick="changeTab(&#39;2&#39;)">标题三</li>
   <li onclick="changeTab(&#39;3&#39;)">标题四</li>
  </ul>
 </p>
  <p id="tabCon">
  <p id="tabCon_0">内容一</p>
  <p id="tabCon_1">内容二</p>
  <p id="tabCon_2">内容三</p>
  <p id="tabCon_3">内容四</p>
 </p>
 </p>
 </body>
 </html>

Methode 3: Anzeigen und Ausblenden nach Besitz Zur Steuerung setzen Sie zunächst die Anzeige aller ausgeblendeten Inhalte auf „Keine“ und stellen Sie die Anzeige der Klasse auf „Alle Titelknoten und Inhaltsknoten durchqueren“ ein andere nicht. Der Code lautet wie folgt:

 <!DOCTYPE html>
 <html>
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 <style>
 *{
  padding: 0;
  margin: 0;
 }
 li{
  list-style: none;
  float:left;
 }
 #tabCon {
  clear: both;
 }
 #tabCon p {
  display:none;
 }
 #tabCon p.fp {
  display:block;
 }
 </style>
 </head>
 <body>
 <p id="tanContainer">
  <p id="tab">
  <ul>
   <li class="fli">标题一</li>
   <li>标题二</li>
   <li>标题三</li>
   <li>标题四</li>
  </ul>
  </p>
  <p id="tabCon">
  <p class="fp">内容一</p>
  <p>内容二</p>
  <p>内容三</p>
  <p>内容四</p>
 </p>
 </p>
 </body>
 <script>
 var tabs=document.getElementById("tab").getElementsByTagName("li");
 var ps=document.getElementById("tabCon").getElementsByTagName("p");

 for(var i=0;i<tabs.length;i++){
  tabs[i].onclick=function(){change(this);}
 }

 function change(obj){
 for(var i=0;i<tabs.length;i++){
  if(tabs[i]==obj){
  tabs[i].className="fli";
  ps[i].className="fp";
 }else{
  tabs[i].className="";
  ps[i].className="";
  }
  }
 } 
 </script>
 </html>

Der Nachteil dieser Methode ist, dass es kein p-Tag mehr geben kann unter dem p des Inhaltsblocks.

Methode 4: Anstatt js zu verwenden, verwenden Sie „input:checked“, um zunächst alle Inhalte auszublenden und die ausgewählten Inhalte anzuzeigen. Der Code lautet wie folgt:

 <!DOCTYPE html>
 <html>
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 <title>input:checked实现tab切换</title>
 <style>
 input{
 opacity: 0;/*隐藏input的选择框*/
 }
 label{
 cursor: pointer;/*鼠标移上去变成手状*/
 float: left;
 }
 label:hover{
 background: #eee;
 }
 input:checked+label{
 color: red;
 }
 /*选择前面有.tabs input:nth-of-type(x):checked的.panels .panel:nth-child(x)*/
 .tabs input:nth-of-type(1):checked~.panels .panel:nth-child(1),
 .tabs input:nth-of-type(2):checked~.panels .panel:nth-child(2){
 opacity: 1;
 }
 .panel{
 opacity: 0;
 position: absolute;/*使内容区域位置一样*/
 }
 </style>
 </head>
 <body>
 <p class="tabs">
  <input checked id="one" name="tabs" type="radio">
  <label for="one">标题一</label>
 
  <input id="two" name="tabs" type="radio">
  <label for="two">标题二</label>
 
  <p class="panels">
   <p class="panel">
   <p>内容一</p>
   </p>
   <p class="panel">
   <p>内容二</p>
   </p>
  </p>
 </p>
 </body>
 </html>

Der Nachteil dieser Methode besteht darin, dass der Wechsel zwischen verschiedenen Bereichen nur möglich ist erfolgt durch Anklicken.

Das Obige ist eine Zusammenfassung der Tab-Wechsel-Implementierungsmethode für alle. Ich hoffe, dass es für alle hilfreich ist. Befolgen Sie diese Idee, um Ihre eigenen Tab-Wechsel-Spezialeffekte zu erstellen.

Weitere verwandte Artikel zu den vier Methoden des Tab-Wechsels mit Javascript finden Sie auf der chinesischen PHP-Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn