这次来做一个简单的选项卡。

选项卡其实就分3个部分:html代码,用于显示的内容;css代码,用于显示的样式;javascript代码,用于点击事件。


老规矩,先写一个html坯子。

 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
<title>选项卡</title>
</head> <body>
<div id="tab">
<h3 class="active">教育</h3>
<h3>娱乐</h3>
<h3>汽车</h3> <div class="content">教育内容</div>
<div>娱乐内容</div>
<div>汽车内容</div>
</div>
</body>
</html>

html代码里只给“教育”和“教育内容”设置class的目的是为了做一个标记,表示这个是点选或者默认显示的内容。

效果:

接下来,我们给整个块加一个框,并且给各个元素都加上边框,这样看得更清楚一些。

 <style type="text/css">
#tab {
border: 2px solid;
}
#tab h3 {
border: 1px solid #cccccc;
}
#tab div {
border: 1px solid #cccccc;
}
</style>

效果:

我们把3个标题向左浮动,并且调整一下字体的大小,布局等等。

 <style type="text/css">
#tab {
border: 2px solid;
}
#tab h3 {
border: 1px solid #cccccc;
margin: 2px 1px 0px 1px;
padding: 0px;
font-size: 14px;
float: left;
right: 5px;
width: 60px;
height: 24px;
line-height: 24px;
text-align: center;
}
#tab div {
border: 1px solid #cccccc;
}
</style>

效果:

3个标题貌似被盖住了...

这是由于标题浮动引起的。

我们把内容给clear一下就行了。

 <style type="text/css">
#tab {
border: 2px solid;
}
#tab h3 {
border: 1px solid #cccccc;
margin: 2px 1px 0px 1px;
padding: 0px;
font-size: 14px;
float: left;
right: 5px;
width: 60px;
height: 24px;
line-height: 24px;
text-align: center;
}
#tab div {
clear: both;
border: 1px solid #cccccc;
}
</style>

效果:

这样看起来好一些,不过距离目的还差得远。

接下来,我们设置内容的样式。设置了父框的宽度,并且将整个父元素块居中。

 <style type="text/css">
#tab {
border: 2px solid;
width: 500px;
margin: 0 auto;
}
#tab h3 {
border: 1px solid #cccccc;
margin: 2px 1px 0px 1px;
padding: 0px;
font-size: 14px;
float: left;
right: 5px;
width: 60px;
height: 24px;
line-height: 24px;
text-align: center;
}
#tab div {
border: 1px solid #cccccc;
clear: both;
height: 100px;
font-size: 14px;
padding: 20px 0px 0px 20px;
}
</style>

效果:

这样看起来就舒服多了!

至于如何体现选项卡的效果,我们通过内容的显示与隐藏来控制。display:[none block]

 <style type="text/css">
#tab {
border: 2px solid;
width: 500px;
margin: 0 auto;
}
#tab h3 {
border: 1px solid #cccccc;
margin: 2px 1px 0px 1px;
padding: 0px;
font-size: 14px;
float: left;
right: 5px;
width: 60px;
height: 24px;
line-height: 24px;
text-align: center;
}
#tab div {
border: 1px solid #cccccc;
clear: both;
height: 100px;
font-size: 14px;
padding: 20px 0px 0px 20px;
display: none;
}
#tab div.content {
display: block;
}
</style>

效果:

这里只看到了“教育内容”,其他内容则被隐藏了。

如何凸现哪个被点选和内容的显示呢,我们给他设置背景颜色。

 #tab h3.active {
background: #cccc00;
}
#tab div.content {
display: block;
background: #cccc00;
}

效果:

现在这个还是一个固定的显示,我们给3个标题注册点击事件,通过点击标题切换标题和内容的标记class,来达到切换选项卡的目的。

 <script type="text/javascript">
window.onload = function() {
var oTab = document.getElementById("tab");
var aH3 = oTab.getElementsByTagName("h3");
var aDiv = oTab.getElementsByTagName("div");
for (var i = 0; i < aH3.length; i++) {
aH3[i].index = i;
aH3[i].onclick = function() {
for (var i = 0; i < aH3.length; i++) {
  aH3[i].className = "";
  aDiv[i].style.display = "none";
  aDiv[this.index].className = "";
  aDiv[this.index].className = "content";
}
this.className = "active";
aDiv[this.index].style.display = "block";
};
}
};
</script>

这样我们点击其他标题

最后我们给微调下,去除表框,添加阴影,附上完整代码:

 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
<title>选项卡</title>
<style type="text/css">
#tab {
width: 500px;
margin: 0 auto;
box-shadow: 5px 5px 5px #888888;
}
#tab h3 {
margin: 0px;
padding: 0px;
font-size: 14px;
float: left;
right: 5px;
width: 60px;
height: 24px;
line-height: 24px;
text-align: center;
}
#tab div {
clear: both;
height: 100px;
font-size: 14px;
padding: 20px 0px 0px 20px;
display: none;
}
#tab h3.active {
background: #cccc00;
}
#tab div.content {
display: block;
background: #cccc00;
}
</style> <script type="text/javascript">
window.onload = function() {
var oTab = document.getElementById("tab");
var aH3 = oTab.getElementsByTagName("h3");
var aDiv = oTab.getElementsByTagName("div");
for (var i = 0; i < aH3.length; i++) {
aH3[i].index = i;
aH3[i].onclick = function() {
for (var i = 0; i < aH3.length; i++) {
aH3[i].className = "";
aDiv[i].style.display = "none";
aDiv[this.index].className = "";
aDiv[this.index].className = "content";
}
this.className = "active";
aDiv[this.index].style.display = "block";
};
}
};
</script>
</head> <body>
<div id="tab">
<h3 class="active">教育</h3>
<h3>娱乐</h3>
<h3>汽车</h3> <div class="content">教育内容</div>
<div>娱乐内容</div>
<div>汽车内容</div>
</div>
</body>
</html>

效果:

这个选项卡只有最基本的功能。如果进一步,我们可以在内容块里加入图片库,把标题背景设置为图片,这样就能做出很漂亮的选项卡。

【Css】一个简单的选项卡的更多相关文章

  1. 使用jQuery.extend创建一个简单的选项卡插件

    选项卡样式如图,请忽略丑陋的样式,样式可以随意更改 主要是基于jquery的extend扩展出的一个简单的选项卡插件,注意:这里封装的类使用的是es6中的class,所以不兼容ie8等低版本浏览器呦! ...

  2. JS入门学习,写一个简单的选项卡

    /* 经过昨天一整天的纠结和摸索.总结下学习初期我最致命的几个问题…… 1.var oDiv = document.getElementById('');    一定要多输,熟悉后o u什么的字母别搞 ...

  3. vue实现一个简单的选项卡

    用vue来实现一个小的选项卡切换,比之前要简单.方便很多. <!DOCTYPE html> <html lang="en"> <head> &l ...

  4. Html+css 一个简单的网页模板

    一个简单的网页模板,有导航.子菜单.banner部分 1 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN&q ...

  5. javascript简单的选项卡

    实现一个简单的选项卡功能 <!DOCTYPE html> <html lang="en"> <head> <meta charset=&q ...

  6. 三行Jquery代码实现简单的选项卡

    今晚,我们来用实现一个简单的选项卡切换代码,主要代码只有两行. 效果: 思路:通过切换JQuery控制div的显隐和样式的改变 其中那个一个div显示,其余全隐藏 实现: <!DOCTYPE h ...

  7. react做的简单的选项卡

    ### 首先安装react的脚手架 cnpm    install   create-react-app   -g    只需要在电脑下载安装一次即可  ###创建项目 create-react-ap ...

  8. Css实现一个简单的幻灯片效果页面

    使用animation动画实现一个简单的幻灯片效果. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 2 ...

  9. CSS布局中一个简单的应用BFC的例子

    什么是BFC BFC(Block Formatting Context),简单讲,它是提供了一个独立布局的环境,每个BFC都遵守同一套布局规则.例如,在同一个BFC内,盒子会一个挨着一个的排,相邻盒子 ...

随机推荐

  1. [修正] Firemonkey 中英文混排折行,省略字符,首字避开标点

    问题:FMX 在移动平台的文字显示并非由该平台的原生 API 来显示,而是由 FMX.TextLayout.GPU 来处理,也许是官方没留意到中文字符的问题,造成在中英文混排折行时,有些问题. 修正: ...

  2. 在 LINQ to Entities 查询中无法构造实体或复杂类型“Mvc_MusicShop_diy.Models.Order”

      错误代码: var orders = db.Orders.Where(o => o.UserId == userid).Select(c => new Order {   OrderI ...

  3. Transaction And Lock--在事务中使用TRY CATCH

    1>当XACT_ABORT被设置为ON时,如果TSQL 语句遇到运行时错误,整个事务会被回滚和结束2>当XACT_ABORT被设置为OFF时,如果TSQL 语句遇到运行时错误,只会回滚当前 ...

  4. NuGet文件下载与应用

    nuget是一款.net下强大的包管理开发工具,Visual Studio 2013和Visual Studio 2015都缺省支持Nuget.在线开发能享受到Nuget的便利,但是如果是离线开发,还 ...

  5. python-数值类型转换

    常用的数据类型转换 函数 说明 int(x [,base ]) 将x转换为一个整数 long(x [,base ]) 将x转换为一个长整数 float(x ) 将x转换到一个浮点数 complex(r ...

  6. ACM-ICPC 2018北京网络赛-A题 Saving Tang Monk II-优先队列

    做法:优先队列模板题,按步数从小到大为优先级,PASS掉曾经以相同氧气瓶走过的地方就好了 题目1 : Saving Tang Monk II 时间限制:1000ms 单点时限:1000ms 内存限制: ...

  7. [Flex] 动态获取组件宽度和高度

    flex中我们有时并不想一开始就设置某个组件的宽度和高度,而想动态获取某个组件经填充后的width和height,但是会发现width和height均为0,这时我们可以注册一下两个事件之一来解决. i ...

  8. java处理excel-xlsx格式大文件的解决方案

    1.第一次读取7M左右的ecxel文件,使用poi 库实现,参考了下面的博文. http://www.cnblogs.com/chenfool/p/3632642.html 使用上面的方法在 下面Wo ...

  9. c++11 perfect forwarding

    完美转发是c++11 引入右值引用之后,在template 中的延伸. 顾名思义,完美转发是将参数不改变属性的条件下,转发给下一个函数. 因为普通函数的参数一旦具名,始终都是lvalue. 如果把rv ...

  10. 时区缩写 UTC, CST, GMT, CEST 以及转换

    UTC是协调世界时(Universal Time Coordinated)英文缩写,是由国际无线电咨询委员会规定和推荐,并由国际时间局(BIH)负责保持的以秒为基础的时间标度.UTC相当于本初子午线( ...