【Css】一个简单的选项卡
这次来做一个简单的选项卡。
选项卡其实就分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】一个简单的选项卡的更多相关文章
- 使用jQuery.extend创建一个简单的选项卡插件
选项卡样式如图,请忽略丑陋的样式,样式可以随意更改 主要是基于jquery的extend扩展出的一个简单的选项卡插件,注意:这里封装的类使用的是es6中的class,所以不兼容ie8等低版本浏览器呦! ...
- JS入门学习,写一个简单的选项卡
/* 经过昨天一整天的纠结和摸索.总结下学习初期我最致命的几个问题…… 1.var oDiv = document.getElementById(''); 一定要多输,熟悉后o u什么的字母别搞 ...
- vue实现一个简单的选项卡
用vue来实现一个小的选项卡切换,比之前要简单.方便很多. <!DOCTYPE html> <html lang="en"> <head> &l ...
- Html+css 一个简单的网页模板
一个简单的网页模板,有导航.子菜单.banner部分 1 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN&q ...
- javascript简单的选项卡
实现一个简单的选项卡功能 <!DOCTYPE html> <html lang="en"> <head> <meta charset=&q ...
- 三行Jquery代码实现简单的选项卡
今晚,我们来用实现一个简单的选项卡切换代码,主要代码只有两行. 效果: 思路:通过切换JQuery控制div的显隐和样式的改变 其中那个一个div显示,其余全隐藏 实现: <!DOCTYPE h ...
- react做的简单的选项卡
### 首先安装react的脚手架 cnpm install create-react-app -g 只需要在电脑下载安装一次即可 ###创建项目 create-react-ap ...
- 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 ...
- CSS布局中一个简单的应用BFC的例子
什么是BFC BFC(Block Formatting Context),简单讲,它是提供了一个独立布局的环境,每个BFC都遵守同一套布局规则.例如,在同一个BFC内,盒子会一个挨着一个的排,相邻盒子 ...
随机推荐
- [LeetCode 题解]: Maximum Depth of Binary Tree
Given a binary tree, find its maximum depth. The maximum depth is the number of nodes along the long ...
- ResorceGovernor--基础和Demo
资源调控器分为三部分:1:资源池,将资源CPU/MEMORY划分到不同的载体上2:负载组,承载负载并将负载映射到不同的资源池3: 分类函数,将不同回话映射到不同的负载组08提供两种预定义的系统资源池1 ...
- .net core 2.0 mvc 获取配置信息
mvc_core_config *:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: 0 ...
- C#设置图片透明度
逐个像素进行Alpha值的设置,网上其他的代码不能处理有透明背景的图片,因此要对Alpha.R.G.B均为0的透明色进行特殊处理,不做转换. private Bitmap SetImageOpacit ...
- linux最基本命令
1.cd命令 这是一个非常基本,也是大家经常需要使用的命令,它用于切换当前目录,它的参数是要切换到的目录的路径,可以是绝对路径,也可以是相对路径.如: cd /root/Docements # 切换到 ...
- C#中的线程
1.线程Thread 多线程的意义在于一个应用程序中,有多个执行部分可以同时执行:对于比较耗时的操作(例如io,数据库操作),或者等待响应(如WCF通信)的操作,可以单独开启后台线程来执行,这样主线程 ...
- hihocoder1580 Matrix
题目链接:(vjudge)戳我 从今天开始不咕咕地填坑啦 考虑一般的求最大子矩阵和...我们一般都是DP,或者直接上悬线法递推. 下面附一个DP的代码: #include<iostream> ...
- iperf3网络测试工具
一.简介: iperf3是一个网络速度测试工具,支持IPv4与IPv6,支持TCP.UDP.SCTP传输协议,可在Windows.Mac OS X.Linux.FreeBSD等各种平台使用,是一个简单 ...
- kvm虚拟化之kvm虚拟机快照备份
kvm虚拟机默认使用raw格式的镜像格式,性能最好,速度最快,它的缺点就是不支持一些新的功能,如支持镜像,zlib磁盘压缩,AES加密等. 要使用镜像功能,磁盘格式必须为qcow2.下面开始kvm ...
- form在模版中的渲 染方式
链接:https://www.jianshu.com/p/46b2aa2d5a23 form.as_p 渲染表单为一系列的p标签,每个p标签包含一个字段: <p> <label fo ...