js tab欄切換代碼實(shí)例解析
今天機(jī)試有個(gè)內(nèi)容是做網(wǎng)易云課堂tab欄切換的,如下

先簡單說下我當(dāng)時(shí)的想法
1.先弄一個(gè)大div盒子,我命名為tab
2.在大盒子tab里面有兩個(gè)小盒子,分別是標(biāo)題欄(tab_list)和內(nèi)容欄(tab_con)
3.采用display:flex;使標(biāo)題欄菜單和內(nèi)容欄的內(nèi)容水平對(duì)齊(可能待會(huì)放的代碼不是很規(guī)范,但實(shí)現(xiàn)對(duì)齊效果)
4.js編寫鼠標(biāo)移入事件,主要是利用display:none和display:block之間的切換。
下面放下我當(dāng)時(shí)寫的代碼吧,可能寫得不是很正規(guī),不符合習(xí)慣,請(qǐng)大家見諒
由于代碼太多分幾部分說
HTML部分——大致布局,標(biāo)題欄和內(nèi)容欄
<div class="tab">
<div class="tab_list">
<ul>
<li class="active" >今日 20:00開搶</li>
<li>明天 10:00開搶</li>
<li>明天 14:00開搶</li>
<li>明天 20:00開搶</li>
<li>后天 10:00</li>
<li>后天 14:00</li>
</ul>
</div>
<div class="tab_con">
<div class="item" style="display: block">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
</div>
</div>
部分內(nèi)容區(qū)item區(qū)域的HTML代碼,基本差不多
<div class="item" style="display: block">
<div class="box">
<div class="product">
<a><img src="img/pic1.png"/></a>
<div class="price" >
<h3>javascript課程</h3>
<h5>妙學(xué)堂</h5>
<p>
<span style="color: red;font-size: 16px;">¥49.9</span>
<span style="text-decoration:line-through ;font-size: 10px;">¥1600</span>
<span style="border: 3px gainsboro dashed;margin-left: 55px;font-size: 16px;">即將開搶</span>
</p>
</div>
</div>
<div class="product">
<a><img src="img/pic1.png"/></a>
<div class="price" >
<h3>javascript課程</h3>
<h5>妙學(xué)堂</h5>
<p>
<span style="color: red;font-size: 16px;">¥49.9</span>
<span style="text-decoration:line-through ;font-size: 10px;">¥1600</span>
<span style="border: 3px gainsboro dashed;margin-left: 55px;font-size: 16px;">即將開搶</span>
</p>
</div>
</div>
<div class="product">
<a><img src="img/pic1.png"/></a>
<div class="price" >
<h3>javascript課程</h3>
<h5>妙學(xué)堂</h5>
<p>
<span style="color: red;font-size: 16px;">¥49.9</span>
<span style="text-decoration:line-through ;font-size: 10px;">¥1600</span>
<span style="border: 3px gainsboro dashed;margin-left: 55px;font-size: 16px;">即將開搶</span>
</p>
</div>
</div>
<div class="product">
<a><img src="img/pic1.png"/></a>
<div class="price" >
<h3>javascript課程</h3>
<h5>妙學(xué)堂</h5>
<p>
<span style="color: red;font-size: 16px;">¥49.9</span>
<span style="text-decoration:line-through ;font-size: 10px;">¥1600</span>
<span style="border: 3px gainsboro dashed;margin-left: 55px;font-size: 16px;">即將開搶</span>
</p>
</div>
</div>
<div class="product">
<a><img src="img/pic1.png"/></a>
<div class="price" >
<h3>javascript課程</h3>
<h5>妙學(xué)堂</h5>
<p>
<span style="color: red;font-size: 16px;">¥49.9</span>
<span style="text-decoration:line-through ;font-size: 10px;">¥1600</span>
<span style="border: 3px gainsboro dashed;margin-left: 55px;font-size: 16px;">即將開搶</span>
</p>
</div>
</div>
</div>
</div>
CSS部分
.tab{
width: 100%;
height: 300px;
text-align: center;
margin: 10px auto;
background-color: ghostwhite;
}
.tab_list ul{
display: flex;
height: 50px;
margin: 0 auto;
padding: 0;
}
.tab li{
list-style: none;
height: 50px;
line-height: 50px;
flex:auto;
}
.tab_list .active{
background-color: red;
color: #ffffff;
}
.tab_con{
margin: 10px auto;
width: 100%;
height: 200px;
}
.item{
display: none;
}
.box{
display: flex;
}
.product{
flex: auto;
}
.product img{
width: 220px;
height: 120px;
}
.price{
position: relative;
width: 220px;
height: 80px;
}
.price p{
margin: 0px;
left: 0px;
position: absolute;
}
JS部分
<script>
var tab_list=document.querySelector('.tab_list');
var lis=tab_list.querySelectorAll('li');
var items=document.querySelectorAll('.item');
for(var i=0;i<lis.length;i++){
lis[i].setAttribute('index',i);
lis[i].onmouseover=function(){
for(var i=0;i<lis.length;i++){
lis[i].className='';
}
this.className='active';
var index=this.getAttribute('index');
console.log(index);
for(var i=0;i<items.length;i++){
items[i].style.display='none';
}
items[index].style.display='block';
}
}
</script>
最終我的效果如下

不是很相像,但還算過得去。。。。。。
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
js實(shí)現(xiàn)讓某個(gè)動(dòng)作延遲幾秒執(zhí)行
這篇文章主要介紹了使用js實(shí)現(xiàn)讓某個(gè)動(dòng)作延遲幾秒執(zhí)行的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06
Swiper 4.x 使用方法(移動(dòng)端網(wǎng)站的內(nèi)容觸摸滑動(dòng))
Swiper是純javascript打造的滑動(dòng)特效插件,面向手機(jī)、平板電腦等移動(dòng)終端,這里為大家簡單介紹一下Swiper4的用法,需要的朋友可以參考下2018-05-05
arcgis.js控制地圖地體的顯示范圍超出區(qū)域自動(dòng)彈回(實(shí)現(xiàn)思路)
這篇文章主要介紹了arcgis.js控制地圖地體的顯示范圍超出區(qū)域自動(dòng)彈回,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01

