亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

JavaScript 實現 Tab 點擊切換實例代碼

2019-11-19 17:02:17
字體:
來源:轉載
供稿:網友

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

1. 功能實現

html 部分

<button style="background-color:#f60; color: #fff;">按鈕1</button><button>按鈕2</button><button>按鈕3</button><div style="display:block;">第一個Nian糕</div><div>第二個Nian糕</div><div>第三個Nian糕</div>

css 部分

div { display: none; width: 155px; height: 100px; border: 1px solid #000;}

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

a. 獲取元素

var btnList = document.getElementsByTagName("button");var divList = document.getElementsByTagName("div");

注釋: 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 = ""; divList[0].style.display = "block";     divList[1].style.display = "none";     divList[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 = "";   divList[0].style.display = "none";     divList[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"; divList[0].style.display = "none";     divList[1].style.display = "none";     divList[2].style.display = "block";  }

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


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

2. 優化

a. 獲取元素

var btnList = document.getElementsByTagName("button");var divList = document.getElementsByTagName("div");

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 = "";   divList[j].style.display = "none";  }  //給點擊的按鈕添加樣式,對應的塊顯示  this.style.color = "#fff";  this.style.backgroundColor = "#f60";  divList[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 divList = document.getElementsByTagName("div");

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="";   divLists[j].style.display="none";  }  this.style.color = "yellow";  this.style.backgroundColor="#f60";  divLists[i].style.display="block"; }}

同樣的,我們也是控制臺來打印一下 i 的值


End of File

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲国产毛片完整版| 成人免费淫片视频软件| 国产一区二区香蕉| 热久久视久久精品18亚洲精品| 欧美在线一区二区三区四| 日韩成人中文字幕在线观看| 欧美精品18videos性欧美| 亚洲国模精品私拍| 亚洲欧美日韩在线高清直播| 国产精品日韩专区| 日韩亚洲在线观看| 日韩一区二区久久久| 国产欧美最新羞羞视频在线观看| 亚洲久久久久久久久久久| 国产91在线高潮白浆在线观看| 亚洲人成在线一二| 久久精品国产成人精品| 久久精品国亚洲| 98视频在线噜噜噜国产| 日韩欧美a级成人黄色| 国产婷婷色综合av蜜臀av| 欧美国产日韩一区二区三区| 久久久亚洲国产天美传媒修理工| 色婷婷亚洲mv天堂mv在影片| 欧美精品在线视频观看| 亚洲影院污污.| 国产欧美一区二区白浆黑人| 国产精品久久久精品| 日韩福利在线播放| 九九热99久久久国产盗摄| 亚洲成人a**站| 尤物yw午夜国产精品视频明星| 中文字幕视频在线免费欧美日韩综合在线看| 欧美日韩视频免费播放| 欧美日本国产在线| 一区二区欧美久久| 色偷偷88888欧美精品久久久| 欧美成人中文字幕| 日韩在线观看你懂的| 亚洲一区第一页| 欧美专区在线视频| 8x海外华人永久免费日韩内陆视频| 日韩欧美成人网| 久久久久中文字幕| 日韩美女福利视频| 国产精品第一视频| 91欧美日韩一区| 国产精品日韩在线观看| 日韩黄色av网站| 91经典在线视频| 国产亚洲aⅴaaaaaa毛片| 欧美国产日韩中文字幕在线| 国语自产精品视频在线看| 中文字幕亚洲在线| 国产精品高潮在线| 亚洲人成电影网| 国产精品久久一区| 91精品久久久久久久久久| 亚洲欧美成人在线| 亚洲另类图片色| 亚洲欧美另类人妖| 欧美—级a级欧美特级ar全黄| 亚洲高清在线观看| 亚洲一区二区日本| 欧美日韩亚洲一区二区三区| 18一19gay欧美视频网站| 成人精品视频久久久久| 久久精品视频播放| 国产精品欧美日韩久久| 91视频88av| 精品国产区一区二区三区在线观看| 国产日产久久高清欧美一区| 日韩精品免费看| 91丨九色丨国产在线| 欧美成人激情在线| 亚洲成人av中文字幕| 最近2019中文字幕第三页视频| 国产精品入口夜色视频大尺度| 日韩成人免费视频| 中文国产成人精品| 久久久久久久久久久91| 日韩中文字幕在线播放| 国产精品国产三级国产aⅴ浪潮| 在线看欧美日韩| 久久福利网址导航| 亚洲国产欧美精品| 国产精品久久久久久久7电影| 在线视频免费一区二区| 国产精品久久久久久久av大片| 91社区国产高清| 国产视频精品自拍| 狠狠色狠色综合曰曰| 国产精品美女免费视频| 成人免费黄色网| 成人激情电影一区二区| 在线观看免费高清视频97| 欧美大尺度电影在线观看| 日韩精品中文在线观看| 亚洲视频日韩精品| 亚洲一区二区国产| 久久精品视频在线观看| 美女扒开尿口让男人操亚洲视频网站| 亚洲一区二区三区视频| 在线视频国产日韩| 国产精品日韩欧美综合| 亚洲tv在线观看| 亚洲美女又黄又爽在线观看| 欧美国产高跟鞋裸体秀xxxhd| 亚洲色图50p| 欧美午夜性色大片在线观看| 午夜精品久久久久久99热软件| 国产精品日日做人人爱| 欧美在线亚洲一区| 欧美亚洲日本网站| 日韩电影中文 亚洲精品乱码| 97成人在线视频| 日韩电影中文 亚洲精品乱码| 久久九九亚洲综合| 日韩精品免费看| 日韩av在线天堂网| 久久久久久国产精品美女| 亚洲国产一区二区三区在线观看| 国产91精品最新在线播放| 亚洲国内精品视频| 亚洲va国产va天堂va久久| 亚洲tv在线观看| 久久九九国产精品怡红院| 成人在线激情视频| 亚洲美女又黄又爽在线观看| 欧美亚洲国产视频| www日韩欧美| 国产欧美日韩亚洲精品| 精品美女永久免费视频| 亚洲а∨天堂久久精品喷水| 91精品国产自产在线老师啪| 精品久久久一区| 91国内揄拍国内精品对白| 91国自产精品中文字幕亚洲| 一区二区欧美亚洲| 秋霞成人午夜鲁丝一区二区三区| 日本精品一区二区三区在线| 日韩精品免费在线播放| 欧美丰满片xxx777| 性色av一区二区三区| 亚洲最新视频在线| 国产精品成人观看视频国产奇米| 欧美激情亚洲精品| 91av国产在线| 亚洲高清一二三区| 亚洲资源在线看| 国产精品小说在线| 久久久噜噜噜久久中文字免| 欧美日韩性生活视频| 亚洲资源在线看| 亚洲丁香婷深爱综合| 日韩专区在线观看| 亚洲精品美女视频| 亚洲国产精久久久久久| 欧美国产日韩免费| 亚洲精品一区二区网址| 国产精品69av| 国产精品亚洲激情| 久久影视电视剧凤归四时歌| 中文字幕亚洲字幕|