1.选项卡效果预览
2.源码与简要说明
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>切换选项卡功能实现</title>
<link rel="stylesheet" href="css/switchTab.css" />
</head>
<body>
<div class="nav-tab">
<ul class="main-tab" id="nav-tab">
<li class="active" index="0">
<a href="#none"><p>星期一</p><p>11-07</p></a>
</li>
<li index="1"><a href="#none"><p>星期二</p><p>11-08</p></a></li>
<li index="2"><a href="#none"><p>星期三</p><p>11-09</p></a></li>
<li index="3"><a href="#none"><p>星期四</p><p>11-10</p></a></li>
<li index="4"><a href="#none"><p>星期五</p><p>11-11</p></a></li>
<li index="5"><a href="#none"><p>星期六</p><p>11-12</p></a></li>
<li index="6"><a href="#none"><p>星期日</p><p>11-13</p></a></a></li>
</ul>
</div>
<div class="tab-content">
<div class="table-div" style="display: block;" tab-index="0">
<table cellpadding="0" cellspacing="0" border="0" class="table">
<colgroup>
<col align="left" width="40%"/>
<col align="left" width="30%"/>
<col align="right" width="30%"/>
</colgroup>
<thead>
<tr>
<td>播出频道</td>
<td>时间</td>
<td>节目</td>
</tr>
</thead>
<tbody>
<tr>
<td>安徽卫视</td>
<td>2016/11/07</td>
<td>天气预报</td>
</tr>
<tr>
<td>CCTV</td>
<td>2016/11/07</td>
<td>天气预报</td>
</tr>
<tr>
<td>广东卫视</td>
<td>2016/11/07</td>
<td>天气预报</td>
</tr>
<tr>
<td>甘肃卫视</td>
<td>2016/11/07</td>
<td>天气预报</td>
</tr>
</tbody>
</table>
</div>
<div class="table-div" style="display: none;" tab-index="0">
<table cellpadding="0" cellspacing="0" border="0" class="table">
<colgroup>
<col align="left" width="40%"/>
<col align="left" width="30%"/>
<col align="right" width="30%"/>
</colgroup>
<thead>
<tr>
<td>播出频道</td>
<td>时间</td>
<td>节目</td>
</tr>
</thead>
<tbody>
<tr>
<td>安徽卫视</td>
<td>2016/11/07</td>
<td>天气预报</td>
</tr>
<tr>
<td>CCTV</td>
<td>2016/11/07</td>
<td>天气预报</td>
</tr>
<tr>
<td>广东卫视</td>
<td>2016/11/07</td>
<td>天气预报</td>
</tr>
<tr>
<td>甘肃卫视</td>
<td>2016/11/07</td>
<td>天气预报</td>
</tr>
</tbody>
</table>
</div>
<div class="table-div" style="display: none;" tab-index="0">
<table cellpadding="0" cellspacing="0" border="0" class="table">
<colgroup>
<col align="left" width="40%"/>
<col align="left" width="30%"/>
<col align="right" width="30%"/>
</colgroup>
<thead>
<tr>
<td>播出频道</td>
<td>时间</td>
<td>节目</td>
</tr>
</thead>
<tbody>
<tr>
<td>安徽卫视</td>
<td>2016/11/07</td>
<td>天气预报</td>
</tr>
<tr>
<td>CCTV</td>
<td>2016/11/07</td>
<td>天气预报</td>
</tr>
<tr>
<td>广东卫视</td>
<td>2016/11/07</td>
<td>天气预报</td>
</tr>
<tr>
<td>甘肃卫视</td>
<td>2016/11/07</td>
<td>天气预报</td>
</tr>
<tr>
<td>安徽卫视</td>
<td>2016/11/07</td>
<td>天气预报</td>
</tr>
<tr>
<td>CCTV</td>
<td>2016/11/07</td>
<td>天气预报</td>
</tr>
<tr>
<td>广东卫视</td>
<td>2016/11/07</td>
<td>天气预报</td>
</tr>
<tr class="last-no-border">
<td>甘肃卫视</td>
<td>2016/11/07</td>
<td>天气预报</td>
</tr>
</tbody>
</table>
</div>
<div class="table-div" style="display: none;" tab-index="1">
<table cellpadding="0" cellspacing="0" border="0" class="table">
<thead>
<tr>
<td>播出频道</td>
<td>时间</td>
<td>节目</td>
</tr>
</thead>
<tbody>
<tr>
<td>安徽卫视</td>
<td>2016/11/08</td>
<td>天气预报</td>
</tr>
<tr>
<td>CCTV</td>
<td>2016/11/08</td>
<td>天气预报</td>
</tr>
</tbody>
</table>
</div>
<div class="table-div" style="display: none;" tab-index="2">
<table cellpadding="0" cellspacing="0" border="0" class="table">
<thead>
<tr>
<td>播出频道</td>
<td>时间</td>
<td>节目</td>
</tr>
</thead>
<tbody>
<tr>
<td>安徽卫视</td>
<td>2016/11/09</td>
<td>天气预报</td>
</tr>
<tr>
<td>CCTV</td>
<td>2016/11/09</td>
<td>天气预报</td>
</tr>
</tbody>
</table>
</div>
<div class="table-div" style="display: none;" tab-index="3">
<table cellpadding="0" cellspacing="0" border="0" class="table">
<thead>
<tr>
<td>播出频道</td>
<td>时间</td>
<td>节目</td>
</tr>
</thead>
<tbody>
<tr>
<td>安徽卫视</td>
<td>2016/11/10</td>
<td>天气预报</td>
</tr>
<tr>
<td>CCTV</td>
<td>2016/11/10</td>
<td>天气预报</td>
</tr>
</tbody>
</table>
</div>
<div class="table-div" style="display: none;" tab-index="4">
<table cellpadding="0" cellspacing="0" border="0" class="table">
<thead>
<tr>
<td>播出频道</td>
<td>时间</td>
<td>节目</td>
</tr>
</thead>
<tbody>
<tr>
<td>安徽卫视</td>
<td>2016/11/11</td>
<td>天气预报</td>
</tr>
<tr>
<td>CCTV</td>
<td>2016/11/11</td>
<td>天气预报</td>
</tr>
</tbody>
</table>
</div>
<div class="table-div" style="display: none;" tab-index="5">
<table cellpadding="0" cellspacing="0" border="0" class="table">
<thead>
<tr>
<td>播出频道</td>
<td>时间</td>
<td>节目</td>
</tr>
</thead>
<tbody>
<tr>
<td>安徽卫视</td>
<td>2016/11/12</td>
<td>天气预报</td>
</tr>
<tr>
<td>CCTV</td>
<td>2016/11/12</td>
<td>天气预报</td>
</tr>
</tbody>
</table>
</div>
<div class="table-div" style="display: none;" tab-index="5">
<table cellpadding="0" cellspacing="0" border="0" class="table">
<thead>
<tr>
<td>播出频道</td>
<td>时间</td>
<td>节目</td>
</tr>
</thead>
<tbody>
<tr>
<td>安徽卫视</td>
<td>2016/11/12</td>
<td>天气预报</td>
</tr>
<tr>
<td>CCTV</td>
<td>2016/11/12</td>
<td>天气预报</td>
</tr>
</tbody>
</table>
</div>
<div class="table-div" style="display: none;" tab-index="6">
<table cellpadding="0" cellspacing="0" border="0" class="table">
<thead>
<tr>
<td>播出频道</td>
<td>时间</td>
<td>节目</td>
</tr>
</thead>
<tbody>
<tr>
<td>安徽卫视</td>
<td>2016/11/13</td>
<td>天气预报</td>
</tr>
<tr>
<td>CCTV</td>
<td>2016/11/13</td>
<td>天气预报</td>
</tr>
</tbody>
</table>
</div>
<div class="div-buttn btn-show" button-index="0">
显示全部<i class="c-icon c-icon-bottom"></i>
</div>
<div class="div-buttn btn-collapse" style="display: none;" button-index="0">
折叠<i class="c-icon c-icon-top"></i>
</div>
</div>
<script type="text/javascript" src="./js/lib/jquery-3.1.1.min.js"></script>
<!--时间:2016-11-09 作者:zhangjiangfeng 描述:选项卡jQuery版本实现 -->
<!--<script type="text/javascript" src="js/switchTab-jQuery.js" ></script>
<!--时间:2016-11-12 作者:zhangjiangfeng 描述:选项卡原生js版本实现 -->
<script type="text/javascript" src="js/switchTab-javaScript.js" ></script>
</body>
</html>
switchTab.css 选项卡样式小技巧简要说明
对于选项卡未选中时利用边框透明border-color: rgba(0,0,0,0);;选中后边框顶部颜色border-top-color显示,
这一技巧从而减少其选项卡盒子模型的计算
/**
* Author Zhangjiangfeng
* Date 2016/11/9 PM 20:35 night
* 选项卡样式实现
*/
html {
font-family: "微软雅黑";
font-size: 12px;
}
div, ul, li, p, a {
margin: 0;
padding: 0;
}
.nav-tab {
width: 565px;
height: 54px;
background-color: #fafafa;
position: relative;
display: inline-block;
}
ul.main-tab {
list-style: none;
margin: 0;
padding: 0;
height: 100%;
font-size: 0; /*消除display: inline-block间隙*/
border-bottom: 1px solid #d9d9d9;
margin-bottom: -2px;
}
ul.main-tab li {
display: inline-block;
height: 48px;
padding-top: 4px;
border-width: 2px 1px 0;
border-color: #999;
border-style: solid;
border-color: rgba(0,0,0,0);
_border-color:tomato;
_filter:chroma(color=#ff6347);
}
ul.main-tab li a {
display: inline-block;
height: 100%;
text-decoration: none;
color: #333;
}
ul.main-tab li p {
font-size: 12px;
line-height: 20px;
padding: 0 20px;
}
/*利用边框的透明从而减少li盒子计算样式*/
ul.main-tab li {
border-width: 2px 1px 0;
border-top-color: #19A6A6;
border-left-color: #d9d9d9;
border-right-color: #d9d9d9;
border-style: solid;
border-color: rgba(0,0,0,0);
}
/* ul.main-tab li:hover {
border-width: 2px 1px 0;
border-top-color: #19A6A6;
border-left-color: #d9d9d9;
border-right-color: #d9d9d9;
border-bottom: #FFFFFF;
border-style: solid;
background-color: #FFFFFF;
}*/
/*选项卡选中样式*/
ul.main-tab li.active {
border-width: 2px 1px 0;
border-top-color: #19A6A6;
border-left-color: #d9d9d9;
border-right-color: #d9d9d9;
border-bottom: #FFFFFF;
border-style: solid;
background-color: #FFFFFF;
}
/*选项卡内容样式*/
.tab-content {
width: 543px;
min-height: 250px;
border: 1px solid #d9d9d9;
border-top: none;
padding: 10px;
position: relative;
}
.table {
width: 100%;
display: table;
border-collapse: collapse;
border: 0;
}
.table tr td {
padding: 10px;
border-bottom: solid 1px #d9d9d9;
}
.table tr.last-no-border td {
border-bottom: none;
}
.div-buttn {
width: 100%;
height: 30px;
cursor: pointer;
line-height: 30px;
text-align: center;
background-color: #fafafa;
}
.div-buttn i {
width: 14px;
height: 14px;
margin-left: 5px;
display: inline-block;
vertical-align: text-bottom;
font-style: normal;
}
.div-buttn i.c-icon {
background: url(../img/icons.png) no-repeat 0 0;
}
.div-buttn i.c-icon-bottom {
background-position: -71px -168px;
}
.div-buttn i.c-icon-top {
background-position:-96px -168px
}
.close {
display: none;
}
switchTab-jQuery/switchTab-javaScript思路简要说明
a.切换不同选项卡显示对应内容
b.点击折叠/展开按钮时,操作的是哪一选项卡对应的内容
3.switchTab-jQuery.js动态效果实现
/*选项卡切换功能借助jQuery实现*/
$(function(){
var $navTab = $("#nav-tab"); //选项卡对象
var $tabCont = $(".tab-content"); //选项卡内容
var $tabContList = $tabCont.find(".table-div"); //选项卡内容列表
var $btnShow = $(".btn-show"); //显示全部
var $btnCollapse = $(".btn-collapse"); //折叠
//选项卡事件绑定
$navTab.on("click", "li", function(){
var $that = $(this);
//获取当前索引值
var navIndex = $that.attr("index");
//当前点击li添加active类,同级兄弟节点移除active类
$that.addClass("active").siblings().removeClass("active");
//当当前点击选项卡navIndex值与表格列表索引tabIndex值相等时显示,否则隐藏
$tabContList.each(function(i){
var $that = $(this);
var tabIndex = $that.attr("tab-index"); //表格列表索引
if(navIndex===tabIndex){
$that.show();
}else{
$that.hide();
}
})
//设置显示全部与折叠按钮索引值---标识当前选中选项卡
$btnShow.attr("button-index",navIndex);
$btnCollapse.attr("button-index", navIndex);
});
//显示全部
$btnShow.on("click", function(){
var $that = $(this);
var btnIndex = $that.attr("button-index"); //获取当前按钮的索引值
$that.hide();
$btnCollapse.show();
$tabContList.each(function(i){
var $that = $(this);
var tabIndex = $that.attr("tab-index"); //表格列表索引
if(btnIndex===tabIndex){
$that.show();
}
})
})
//折叠
$btnCollapse.on("click", function(){
var $that = $(this);
var btnIndex = $that.attr("button-index"); //获取当前按钮的索引值
$that.hide();
$btnShow.show();
$tabContList.each(function(i){
var $that = $(this);
var tabIndex = $that.attr("tab-index"); //表格列表索引
if(btnIndex===tabIndex){
$that.hide();
}
})
});
})
3.switchTab-javaScript效果实现
/*选项卡切换功能js实现*/
window.onload = function(){
var oTab = document.getElementById("nav-tab");
var liArray = oTab.getElementsByTagName("li");
var tabList = document.getElementsByClassName("table-div");
var btnShow = document.getElementsByClassName("btn-show");
var btnCollapse = document.getElementsByClassName("btn-collapse");
for (var i=0; i<liArray.length; i++) {
liArray[i].onclick = function(){
for (var j=0; j<liArray.length; j++) {
//移除class样式
liArray[j].className = "";
}
//添加class样式
this.className = "active";
//获取DOM索引值
var index = this.getAttribute("index");
btnShow[0].setAttribute("button-index", index);
btnCollapse[0].setAttribute("button-index", index);
//内容切换
for (var t = 0; t<tabList.length; t++) {
var tableIndex = tabList[t].getAttribute("tab-index");
if(index === tableIndex){
tabList[t].style.display = "block";
}else{
tabList[t].style.display = "none";
}
}
}
}
//显示全部
btnShow[0].onclick = function(){
var btnIndex = this.getAttribute("button-index");
//表格index与按钮btnIndex
for (var t = 0; t<tabList.length; t++) {
var tableIndex = tabList[t].getAttribute("tab-index");
if(btnIndex === tableIndex){
tabList[t].style.display = "block";
}
}
this.style.display = "none";
btnCollapse[0].style.display = "block";
}
//折叠
btnCollapse[0].onclick = function(){
var btnIndex = this.getAttribute("button-index");
//表格index与按钮btnIndex
for (var t = 0; t<tabList.length; t++) {
var tableIndex = tabList[t].getAttribute("tab-index");
if(btnIndex === tableIndex){
tabList[t].style.display = "none";
}
}
this.style.display = "none";
btnShow[0].style.display = "block";
}
}
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
# js
# 选项卡
# 切换
# 折叠
# 展开
# JS+CSS实现的简单折叠展开多级菜单效果
# js实现可折叠展开的手风琴菜单效果
# Js操作树节点自动折叠展开的几种方法
# js实现简单折叠、展开菜单的方法
# js实现超简单的展开、折叠目录代码
# JS实现鼠标滑过折叠与展开菜单效果代码
# JS实现可展开折叠层的鼠标拖曳效果
# JavaScript实现兼容IE6的收起折叠与展开效果实例
# JS实现适合于后台使用的动画折叠菜单效果
# JS实现的简单折叠展开动画效果示例
# 安徽
# 甘肃
# 广东
# 移除
# 的是
# 这一
# 微软
# 绑定
# 小技巧
# 星期日
# border
# tbody
# CCTV
# block
# buttn
# cellspacing
# cellpadding
# left
# width
相关文章:
沈阳制作网站公司排名,沈阳装饰协会官方网站?
矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?
如何在阿里云香港服务器快速搭建网站?
济南企业网站制作公司,济南社保单位网上缴费步骤?
网站制作说明怎么写,简述网页设计的流程并说明原因?
免费制作小说封面的网站有哪些,怎么接网站批量的封面单?
如何在阿里云高效完成企业建站全流程?
保定网站制作方案定制,保定招聘的渠道有哪些?找工作的人一般都去哪里看招聘信息?
如何基于云服务器快速搭建网站及云盘系统?
如何在宝塔面板中修改默认建站目录?
如何撰写建站申请书?关键要点有哪些?
西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?
rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted
如何制作算命网站,怎么注册算命网站?
建站为何优先选择香港服务器?
网站建设制作、微信公众号,公明人民医院怎么在网上预约?
深圳 网站制作,深圳招聘网站哪个比较好一点啊?
定制建站平台哪家好?企业官网搭建与快速建站方案推荐
网站插件制作软件免费下载,网页视频怎么下到本地插件?
网站制作公司排行榜,四大门户网站排名?
建站之家VIP精选网站模板与SEO优化教程整合指南
如何零基础开发自助建站系统?完整教程解析
潍坊网站制作公司有哪些,潍坊哪家招聘网站好?
如何在企业微信快速生成手机电脑官网?
南京做网站制作公司,南京哈发网络有限公司,公司怎么样,做网页美工DIV+CSS待遇怎么样?
SQL查询语句优化的实用方法总结
c# await 一个已经完成的Task会发生什么
三星网站视频制作教程下载,三星w23网页如何全屏?
如何选择靠谱的建站公司加盟品牌?
高性能网站服务器配置指南:安全稳定与高效建站核心方案
图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?
b2c电商网站制作流程,b2c水平综合的电商平台?
打鱼网站制作软件,波克捕鱼官方号怎么注册?
建站之星备案流程有哪些注意事项?
如何自定义建站之星模板颜色并下载新样式?
如何用景安虚拟主机手机版绑定域名建站?
建站168自助建站系统:快速模板定制与SEO优化指南
如何选择适配移动端的WAP自助建站平台?
义乌企业网站制作公司,请问义乌比较好的批发小商品的网站是什么?
如何通过主机屋免费建站教程十分钟搭建网站?
如何在阿里云完成域名注册与建站?
重庆网站制作公司哪家好,重庆中考招生办官方网站?
定制建站模板如何实现SEO优化与智能系统配置?18字教程
C++如何编写函数模板?(泛型编程入门)
如何通过NAT技术实现内网高效建站?
青岛网站建设如何选择本地服务器?
如何用AWS免费套餐快速搭建高效网站?
怀化网站制作公司,怀化新生儿上户网上办理流程?
如何选择高性价比服务器搭建个人网站?
建站10G流量真的够用吗?如何应对访问高峰?
*请认真填写需求信息,我们会在24小时内与您取得联系。