JavaScript实现简易tab栏切换内容栏
本文实例为大家分享了JavaScript实现简易tab栏切换内容栏的具体代码,供大家参考,具体内容如下
html+css部分
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> <style> /* 初始化css,因为有默认边距 *{ margin:0; padding:0;} h1,h2,h3,h4,h5,h6{ font-size:100%; font-weight:normal;} ol,ul{ list-style:none;} img,fieldset{ border:0 none; display:block;} */ div,ul,li{ box-sizing: border-box; margin: 0; padding: 0; } ul{ list-style-type: none; } a{ text-decoration: none; } #nav{ width: 450px; height: 400px; margin: 100px auto;/*左右居中*/ background-color: pink; padding: 0; font-size: 14px; } li{ float: left; width: 150px; height: 30px; text-align: center; line-height: 0.6rem; border: 0.02rem solid #ccc; } .content{ clear: both; position: relative; } .content div{ width: 450px; height: 370px; position: absolute; display: none; } .tab .choose{ background-color: skyblue; } .content .current{ display: block; } </style> <script src="jQuery.mini.js"></script> </head> <body> <div id="nav"> <div class="tab"> <ul> <li class="choose" ><a href="#" > 1</a></li> <li><a href="#" >2</a></li> <li><a href="#" >3</a></li> </ul> </div> <div class="content"> <div class="current">1</div> <div>2</div> <div>3</div> </div> </div> </body> </html>
原生js代码
var lis = document.querySelectorAll('li'); var divs = document.querySelector('.content').querySelectorAll('div'); for(var i=0 ; i<lis.length ; i++){ lis[i].setAttribute('dateIndex',i);//设置每一个li的index,方便后面锁定内容栏 lis[i].addEventListener('click',function(){ for(var j=0 ; j<lis.length ; j++){ lis[j].className = '';//将所有的li的样式设置为空 } this.className = 'choose';//设置当前点击的li的样式(排他) var index = this.getAttribute('dateIndex');//获取当前li的index // console.log(index); for(var j=0 ; j<lis.length ; j++){ divs[j].className = '';//排他 // lis[i].className = 'choose'; } divs[index].className = 'current'; }) }
## jQuery方法 ```javascript //jQuer方法 $(function(){ $("li").click(function(){ $(this).addClass("choose");//为当前点击的li添加样式 $(this).siblings("li").removeClass("choose");//它的兄弟元素消除样式(排他) var index = $(this).index();//获取当前点击的li的index $(".content div").eq(index).show().siblings("div").hide(); //通过index获取到相对应的内容框,通过show()显示出来,在选取它的兄弟元素隐藏,分解======》 //$(".content div").eq(index).show(); // $(".content div").eq(index).siblings("div").hide() }) })
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。
赞 (0)