欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

tab欄切換原理

 更新時(shí)間:2017年03月22日 10:52:09   作者:wmaqingbo  
本文主要介紹了tab欄切換的原理以及實(shí)現(xiàn)方法代碼。具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧

本文是我學(xué)習(xí)tab欄切換時(shí)的筆記,步驟很詳細(xì)。比較適用于JavaScript初學(xué)者

1.基礎(chǔ) - 排他思想

如圖,點(diǎn)擊任意一個(gè)按鈕,當(dāng)前按鈕應(yīng)該顯示橘色,其他顯示默認(rèn)顏色灰色。

代碼運(yùn)行步驟:

利用for循環(huán)遍歷5個(gè)按鈕;

選中的按鈕進(jìn)行 onclick 事件時(shí),首先刪除所有按鈕的類名,使其全部顯示灰色(34行);

然后給當(dāng)前點(diǎn)擊的按鈕添加指定類名,使其顯示橘色(37行)。

示例代碼:

<!DOCTYPE html>
<html>
 <head>
 <meta charset="utf-8">
 <title>tab欄切換效果</title>
 <style media="screen">
  *{
  margin: 0;
  padding: 0;
  border: 0 none;
  outline: none;
  }
  #btns{
  width: 300px;
  margin: 100px auto;
  }
  #btns button {
  width: 60px;
  height: 30px;
  float: left;
  border-right: 1px solid #ccc;
  }
  .color{
  background-color: #eb923f;
  }
 </style>
 <script type="text/javascript">
  window.onload = function () {
  var btns = document.getElementById("btns").getElementsByTagName("button");
  for (var i = 0; i < btns.length; i++) {
   btns[i].onclick = function () {
   for (var j = 0; j < btns.length; j++) {
    //把所有的button清空類名
    btns[j].className = "";
   }
   //點(diǎn)擊的那個(gè)盒子添加指定類名
   this.className = "color";
   }
  }
  }
 </script>
 </head>
 <body>
 <div id="btns">
  <button class="color">按鈕1</button>
  <button>按鈕2</button>
  <button>按鈕3</button>
  <button>按鈕4</button>
  <button>按鈕5</button>
 </div>
 </body>
</html>

2.tab欄切換

如圖:在排他思想的基礎(chǔ)上,五個(gè)按鈕底下添加五個(gè)新盒子,并用一個(gè)大盒子將按鈕和底下的盒子包裹。

底下的盒子全部隱藏,默認(rèn)只顯示第一個(gè)。

新增步驟:

為btns[i]添加自定義屬性index,用來(lái)關(guān)聯(lián)下面的大盒子(42行);

點(diǎn)擊按鈕后先讓底下的盒子全部隱藏(54行);

然后給當(dāng)前所點(diǎn)擊按鈕相關(guān)聯(lián)的盒子添加指定屬性(57行)。

示例代碼:

<!DOCTYPE html>
<html>
 <head>
 <meta charset="utf-8">
 <title>tab欄切換效果</title>
 <style media="screen">
  *{
  margin: 0;
  padding: 0;
  border: 0 none;
  outline: none;
  }
  .baohan{
  width: 300px;
  margin: 100px auto;
  border: 1px solid #ccc;
  }
  #btns button {
  width: 60px;
  height: 30px;
  float: left;
  border-right: 1px solid #ccc;
  }
  #divs div {
  width: 300px;
  height: 100px;
  font-size: 60px;
  padding-top: 60px;
  background-color: #eb923f;
  text-align: center;
  display: none;
  }
  .color{
  background-color: #eb923f;
  }
 </style>
 <script type="text/javascript">
  window.onload = function () {
  var btns = document.getElementById("btns").getElementsByTagName("button");
  var divs = document.getElementById("divs").getElementsByTagName("div");
  for (var i = 0; i < btns.length; i++) {
   btns[i].index = i; //自定義屬性,用于關(guān)聯(lián)下面的大盒子
   btns[i].onclick = function () {

   for (var j = 0; j < btns.length; j++) {
    //把所有的button清空類名
    btns[j].className = "";
   }
   //點(diǎn)擊的那個(gè)盒子添加指定類名
   this.className = "color";
   for (var i = 0; i < divs.length; i++) {
    //先讓底下的div全部隱藏
    divs[i].style.display = "none";
   }
   //然后給當(dāng)前所點(diǎn)擊按鈕相關(guān)聯(lián)的盒子添加指定屬性
   divs[this.index].style.display = "block";
   }
  }
  }
 </script>
 </head>
 <body>
 <div class="baohan">
  <div id="btns">
  <button class="color">按鈕1</button>
  <button>按鈕2</button>
  <button>按鈕3</button>
  <button>按鈕4</button>
  <button>按鈕5</button>
  </div>
  <div id="divs">
  <div style="display:block;">1</div>
  <div>2</div>
  <div>3</div>
  <div>4</div>
  <div>5</div>
  </div>
 </div>
 </body>
</html>

以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,同時(shí)也希望多多支持腳本之家!

相關(guān)文章

  • js中復(fù)選框的取值及賦值示例詳解

    js中復(fù)選框的取值及賦值示例詳解

    這篇文章主要給大家介紹了關(guān)于js中復(fù)選框的取值及賦值的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10
  • JS將圖片轉(zhuǎn)Base64的2種方法代碼

    JS將圖片轉(zhuǎn)Base64的2種方法代碼

    這篇文章主要給大家介紹了關(guān)于JS將圖片轉(zhuǎn)Base64的2種方法,base64 其實(shí)是一種編碼轉(zhuǎn)換方式,將ASCII字符轉(zhuǎn)換成普通文本,是網(wǎng)絡(luò)上最常見(jiàn)的用于傳輸8Bit字節(jié)代碼的編碼方式之一,需要的朋友可以參考下
    2024-05-05
  • CSS代碼格式化和壓縮的方法與技巧

    CSS代碼格式化和壓縮的方法與技巧

    下面腳本之家編輯就將一些css的格式化與壓縮技巧簡(jiǎn)單的介紹下,一把情況需要盡量的縮寫(xiě)樣式,減少體積,然后用工具進(jìn)行壓縮,然后再測(cè)試網(wǎng)頁(yè)。
    2007-06-06
  • 酷! 不同風(fēng)格頁(yè)面布局幻燈片特效js實(shí)現(xiàn)

    酷! 不同風(fēng)格頁(yè)面布局幻燈片特效js實(shí)現(xiàn)

    這篇文章主要為大家詳細(xì)介紹了超酷不同風(fēng)格頁(yè)面布局幻燈片特效,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-08-08
  • javascript中等于(==)與全等(===)的區(qū)別說(shuō)明

    javascript中等于(==)與全等(===)的區(qū)別說(shuō)明

    等于(==)的情況下 只要值相同就返回True。而全等(===)的時(shí)候需要值和類型都要匹配才能返回True.
    2011-01-01
  • 使用JavaScript解決網(wǎng)頁(yè)圖片拉伸問(wèn)題(推薦)

    使用JavaScript解決網(wǎng)頁(yè)圖片拉伸問(wèn)題(推薦)

    本文給大家介紹使用javascript解決網(wǎng)頁(yè)圖片拉伸問(wèn)題,本文給大家介紹的非常詳細(xì),具有參考借鑒價(jià)值,感興趣的朋友一起看看吧
    2016-11-11
  • JavaScript實(shí)現(xiàn)手寫(xiě)promise的示例代碼

    JavaScript實(shí)現(xiàn)手寫(xiě)promise的示例代碼

    promise?作為前端開(kāi)發(fā)中常用的函數(shù),解決了?js?處理異步時(shí)回調(diào)地獄的問(wèn)題,大家應(yīng)該也不陌生了,今天來(lái)學(xué)習(xí)一下?promise?的實(shí)現(xiàn)過(guò)程吧
    2023-04-04
  • chrome調(diào)試javascript詳解

    chrome調(diào)試javascript詳解

    這篇文章主要介紹了chrome調(diào)試javascript詳解,需要的朋友可以參考下
    2015-10-10
  • 原生JS實(shí)現(xiàn)簡(jiǎn)單屏幕截圖

    原生JS實(shí)現(xiàn)簡(jiǎn)單屏幕截圖

    本文主要介紹了原生JS實(shí)現(xiàn)簡(jiǎn)單屏幕截圖,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • JS實(shí)現(xiàn)小星星特效

    JS實(shí)現(xiàn)小星星特效

    這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)小星星特效,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-12-12

最新評(píng)論