首頁 web前端 js教程 JavaScript實作Tab點擊切換實例程式碼分享(圖文)

JavaScript實作Tab點擊切換實例程式碼分享(圖文)

Mar 27, 2017 pm 02:26 PM

Tab 選項卡切換效果在現如今的網頁中,運用的也是比較多的,包括點擊切換、滑動切換、延遲切換、自動切換等多種效果,在這篇博文裡,我們是透過原生JavaScript 來實現Tab 點擊切換的效果。

Tab 選項卡切換效果在現如今的網頁中,運用的也是比較多的,包括點擊切換、滑動切換、延遲切換、自動切換等多種效果,在這篇博文裡,我們是透過原生Javascript 來實現Tab 點選切換的效果

1.功能實作

html 部分

<button style="background-color:#f60; color: #fff;">按钮1</button>
<button>按钮2</button>
<button>按钮3</button>
<p style="display:block;">第一个Nian糕</p>
<p>第二个Nian糕</p>
<p>第三个Nian糕</p>
登入後複製

css 部分

p {
 display: none;
 width: 155px;
 height: 100px;
 border: 1px solid #000;
}
登入後複製

接下來是JS 部分,根據每一步要實現的功能,進而轉換成程式碼,每當我們要實現一個效果的時候,先不要急著敲程式碼,而是先思考要怎麼去實現,結構是什麼樣的,某個功能需要用到什麼事件等等,自己在腦海裡把整個流程過一遍,再去把每一步的邏輯轉換成程式碼

a. 取得元素

var btnList = document.getElementsByTagName("button");
var pList = document.getElementsByTagName("p");
登入後複製
登入後複製
登入後複製

註解: document.getElementsByTagName 回傳的是一個[類數組物件],可以使用數組的方法對其進行處理,但類別數組物件並不具有數組所具有的方法

b. 給元素綁定點擊事件

//第一个按钮的点击事件
btnList[0].onclick = function () {
 btnList[0].style.color = "#fff";
 btnList[0].style.backgroundColor = "#f60";
 btnList[1].style.color = "";
 btnList[1].style.backgroundColor = "";
 btnList[2].style.color = "";
 btnList[2].style.backgroundColor = "";
 pList[0].style.display = "block";    
 pList[1].style.display = "none";    
 pList[2].style.display = "none";    
}
登入後複製
//第二个按钮的点击事件
btnList[1].onclick = function () {
 btnList[0].style.color = "";
 btnList[0].style.backgroundColor = "";
 btnList[1].style.color = "#fff";
 btnList[1].style.backgroundColor = "#f60";
 btnList[2].style.color = "";
 btnList[2].style.backgroundColor = "";  
 pList[0].style.display = "none";    
 pList[1].style.display = "block";    
}
登入後複製
//第三个按钮的点击事件
btnList[2].onclick = function () {
 btnList[0].style.color = "";
 btnList[0].style.backgroundColor = "";
 btnList[1].style.color = "";
 btnList[1].style.backgroundColor = "";
 btnList[2].style.color = "#fff";
 btnList[2].style.backgroundColor = "#f60";
 pList[0].style.display = "none";    
 pList[1].style.display = "none";    
 pList[2].style.display = "block";  
}
登入後複製

現在我們已經實現了一個Tab 切換的效果了,來看一下效果


雖然很簡陋,但已經達到我們想要的效果了,讀者可根據自己想要的樣式來設定CSS,接下來我們要做的就是,對JS 程式碼進行最佳化

2. 最佳化

a. 取得元素

var btnList = document.getElementsByTagName("button");
var pList = document.getElementsByTagName("p");
登入後複製
登入後複製
登入後複製

b. 給每一個button 元素綁定點擊事件

for(var i = 0; i < btnList.length; i++ ) {
 btnList[i].index = i; //给每个按钮添加index属性,标记是第几个按钮
 btnList[i].onclick = function() {
  for(var j = 0; j < btnList.length; j++) {
   //将所有的按钮样式去掉,块隐藏
   btnList[j].style.color = "";
   btnList[j].style.backgroundColor = "";
   pList[j].style.display = "none";
  }
  //给点击的按钮添加样式,对应的块显示
  this.style.color = "#fff";
  this.style.backgroundColor = "#f60";
  pList[this.index].style.display = "block";
 }
}
登入後複製

index 傳回字元位置,它是被搜尋字串中第一個成功匹配的開始位置,從零開始

this 是Javascript 的一個關鍵字,它代表函數運行時,自動產生的一個內部物件,只能在函數內部使用this,關於this 的值,會跟隨函數使用場景的不同而發生變化,但是我們只需要記住一個原則就可以了,this指的是呼叫函數的那個物件

在這裡this 指向對應的點擊按鈕,我們可以透過控制台列印來看到this 所輸出的內容


3. Let 指令

ES 6 中新增 let 指令,用來宣告變數,其用法類似 var,但是所宣告的變數,只在 let 指令所在的程式碼區塊內有效


在上面的程式碼中,我們在程式碼區塊裡,分別用var let 宣告了兩個變量,接著在程式碼區塊內外列印這兩個變量,可以看到,var 聲明的變數傳回了正確的值,程式碼區塊內列印let 宣告的變數傳回了正確的值,而在程式碼區塊外列印let 宣告的變數報錯,這表明,let 宣告的變數只在它所在的程式碼區塊有效


上面程式碼中,變數i var 宣告的,在全域範圍內都有效,所以全域只有一個變數 i,每一次循環,變數 i 的值都會改變,而迴圈內被賦給陣列 a function 在運行時,會透過閉包讀到這同一個變數i,導致最後輸出的是最後一輪的 i 的值,也就是10,而如果使用 let,宣告的變數只在區塊層級作用域內有效,最後輸出的是 6

#a. 取得元素

var btnList = document.getElementsByTagName("button");
var pList = document.getElementsByTagName("p");
登入後複製
登入後複製
登入後複製

##b.給每一個button 元素綁定點擊事件

for(let i = 0; i < btnLists.length; i++) {
 btnLists[i].onclick = function() {
  for(var j = 0;j < btnLists.length;j++){
   btnLists[j].style.color="";
   btnLists[j].style.backgroundColor="";
   pLists[j].style.display="none";
  }
  this.style.color = "yellow";
  this.style.backgroundColor="#f60";
  pLists[i].style.display="block";
 }
}
登入後複製
同樣的,我們也是控制台來列印一下i 的值


End of File

#行文過程中出現錯誤或不妥之處在所難免,希望大家能夠給予指正,以免誤導更多人,也希望大家多多支持劇本之家。

以上是JavaScript實作Tab點擊切換實例程式碼分享(圖文)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1674
14
CakePHP 教程
1429
52
Laravel 教程
1333
25
PHP教程
1278
29
C# 教程
1257
24
WebSocket與JavaScript:實現即時監控系統的關鍵技術 WebSocket與JavaScript:實現即時監控系統的關鍵技術 Dec 17, 2023 pm 05:30 PM

WebSocket與JavaScript:實現即時監控系統的關鍵技術引言:隨著互聯網技術的快速發展,即時監控系統在各個領域中得到了廣泛的應用。而實現即時監控的關鍵技術之一就是WebSocket與JavaScript的結合使用。本文將介紹WebSocket與JavaScript在即時監控系統中的應用,並給出程式碼範例,詳細解釋其實作原理。一、WebSocket技

如何使用WebSocket和JavaScript實現線上語音辨識系統 如何使用WebSocket和JavaScript實現線上語音辨識系統 Dec 17, 2023 pm 02:54 PM

如何使用WebSocket和JavaScript實現線上語音辨識系統引言:隨著科技的不斷發展,語音辨識技術已成為了人工智慧領域的重要組成部分。而基於WebSocket和JavaScript實現的線上語音辨識系統,具備了低延遲、即時性和跨平台的特點,成為了廣泛應用的解決方案。本文將介紹如何使用WebSocket和JavaScript來實現線上語音辨識系

解決CentOS7的Tab鍵無法補全指令問題 解決CentOS7的Tab鍵無法補全指令問題 Jan 17, 2024 pm 01:30 PM

今天在centOS上做實驗,發現之前在Ubuntu下使用的比較習慣的tab鍵補全命令的方式不能使用,於是非常好奇,經過查找資料並親自測試,將可行的解決方式記錄如下:1)首先需要在終端機中執行以下指令:#yuminstallbash-completion//也可以使用通配符安裝:yuminstallbash-c*或是你可以安裝一些初始化的套件組yum-yyalinstallBaseCompatibilitylibrariesDebuggingToolsDial-upNetworkingsupppogroupinstallBaseCompatibilitylibrariesDebuggingToolsDial-upNetworkingsupppogroup

如何利用JavaScript和WebSocket實現即時線上點餐系統 如何利用JavaScript和WebSocket實現即時線上點餐系統 Dec 17, 2023 pm 12:09 PM

如何利用JavaScript和WebSocket實現即時線上點餐系統介紹:隨著網路的普及和技術的進步,越來越多的餐廳開始提供線上點餐服務。為了實現即時線上點餐系統,我們可以利用JavaScript和WebSocket技術。 WebSocket是一種基於TCP協定的全雙工通訊協議,可實現客戶端與伺服器的即時雙向通訊。在即時線上點餐系統中,當使用者選擇菜餚並下訂單

如何使用WebSocket和JavaScript實現線上預約系統 如何使用WebSocket和JavaScript實現線上預約系統 Dec 17, 2023 am 09:39 AM

如何使用WebSocket和JavaScript實現線上預約系統在當今數位化的時代,越來越多的業務和服務都需要提供線上預約功能。而實現一個高效、即時的線上預約系統是至關重要的。本文將介紹如何使用WebSocket和JavaScript來實作一個線上預約系統,並提供具體的程式碼範例。一、什麼是WebSocketWebSocket是一種在單一TCP連線上進行全雙工

JavaScript與WebSocket:打造高效率的即時天氣預報系統 JavaScript與WebSocket:打造高效率的即時天氣預報系統 Dec 17, 2023 pm 05:13 PM

JavaScript和WebSocket:打造高效的即時天氣預報系統引言:如今,天氣預報的準確性對於日常生活以及決策制定具有重要意義。隨著技術的發展,我們可以透過即時獲取天氣數據來提供更準確可靠的天氣預報。在本文中,我們將學習如何使用JavaScript和WebSocket技術,來建立一個高效的即時天氣預報系統。本文將透過具體的程式碼範例來展示實現的過程。 We

簡易JavaScript教學:取得HTTP狀態碼的方法 簡易JavaScript教學:取得HTTP狀態碼的方法 Jan 05, 2024 pm 06:08 PM

JavaScript教學:如何取得HTTP狀態碼,需要具體程式碼範例前言:在Web開發中,經常會涉及到與伺服器進行資料互動的場景。在與伺服器進行通訊時,我們經常需要取得傳回的HTTP狀態碼來判斷操作是否成功,並根據不同的狀態碼來進行對應的處理。本篇文章將教你如何使用JavaScript來取得HTTP狀態碼,並提供一些實用的程式碼範例。使用XMLHttpRequest

javascript如何使用insertBefore javascript如何使用insertBefore Nov 24, 2023 am 11:56 AM

用法:在JavaScript中,insertBefore()方法用於在DOM樹中插入一個新的節點。這個方法需要兩個參數:要插入的新節點和參考節點(即新節點將要插入的位置的節點)。

See all articles