关于实现CSS Tab布局的简单实例

本文主要为大家带来一篇必看css实现tab布局的简单实例。希望能让大家对css tab布局有一个更清楚的认识。

一、布局方式

1、内容与tab分离

 

立即学习“前端免费学习笔记(深入)”;

内容1

内容2

内容3

内容4

登录后复制登录后复制

 

立即学习“前端免费学习笔记(深入)”;

ul,li{  margin:0;  padding:0;  list-style:none;}.container{  width:400px;  height:300px;  background-color:silver;}.tab-content{  width:100%;  height:80%;  overflow:hidden;}.tab-content .item{  width:100%;  height:100%;}.tab-control{  width:100%;  height:20%;}.tab-control ul{  height:100%;}.tab-control li{  width:25%;  height:100%;  float:left;  border:1px solid silver;  box-sizing:border-box;  background-color:white;  cursor: pointer;}.tab-control li:hover{  background-color:#7b7474}.tab-control a{  display:inline-block;  width:100%;  height:100%;  line-height:100%;  text-align:center;  text-decoration: none;}.tab-control a::after{  content:"";  display:inline-block;  height:100%;  vertical-align:middle;}.tab-content .item:target{  background:yellow;}

登录后复制

关于实现CSS Tab布局的简单实例

2、内容与tab一体 

 

立即学习“前端免费学习笔记(深入)”;

  • 1

    1

  • 2

    2

  • 3

    3

  • 4

    4

登录后复制登录后复制

 

立即学习“前端免费学习笔记(深入)”;

ul,li,p{  margin:0;  padding:0;  list-style:none;}.container{  width:400px;  height:300px;  background-color:silver;  border:1px solid silver;}.container ul{  width:100%;  height:100%;  overflow:hidden;}.container .item{  float:left;  width:25%;  height:100%;  background-color:white;}.container .item .title{  line-height:40px;  border:1px solid silver;  box-sizing:border-box;  text-align:center;  cursor:pointer;}.container .item .content{  width:400%;  height:100%;  background-color:yellow;}.ml1{  margin-left:-100%;}.ml2{  margin-left:-200%;}.ml3{  margin-left:-300%;}.active{  position:relative;  z-index:1}.container .item:hover{  position:relative;  z-index:1}.container .item:hover .title{  border-bottom:none;  background-color:yellow;}

登录后复制登录后复制

关于实现CSS Tab布局的简单实例

利用负margin,将内容区对齐,然后内容去添加背景色,避免不同tab对应的区域透视重叠。

二、CSS实现交互

1、锚点实现(target)

(1)针对布局一:item从上往下排列,父元素tab-content加上overflow:hidden。利用锚点,点击不同a标签的时候,具有对应ID的item会切换到tab-content的视图中,然后利用hover给tab按钮加上切换样式。

 

立即学习“前端免费学习笔记(深入)”;

内容1

内容2

内容3

内容4

登录后复制登录后复制

 

立即学习“前端免费学习笔记(深入)”;

ul,li{  margin:0;  padding:0;  list-style:none;}.container{  width:400px;  height:300px;  background-color:silver;}.tab-content{  width:100%;  height:80%;  overflow:hidden;}.tab-content .item{  width:100%;  height:100%;}.tab-control{  width:100%;  height:20%;}.tab-control ul{  height:100%;}.tab-control li{  width:25%;  height:100%;  float:left;  border:1px solid silver;  box-sizing:border-box;  background-color:white;  cursor: pointer;}.tab-control li:hover{  background-color:#7b7474}.tab-control a{  display:inline-block;  width:100%;  height:100%;  line-height:100%;  text-align:center;  text-decoration: none;}.tab-control a::after{  content:"";  display:inline-block;  height:100%;  vertical-align:middle;}

登录后复制

上述方法只是利用了锚点切换,没有使用:target。修改CSS

 

立即学习“前端免费学习笔记(深入)”;

ul,li{  margin:0;  padding:0;  list-style:none;}.container{  width:400px;  height:300px;  background-color:silver;}.tab-content{  position:relative;  width:100%;  height:80%;  overflow:hidden;}.tab-content .item{  position:absolute;  left:0;  top:0;  width:100%;  height:100%;}.tab-control{  width:100%;  height:20%;}.tab-control ul{  height:100%;}.tab-control li{  width:25%;  height:100%;  float:left;  border:1px solid silver;  box-sizing:border-box;  background-color:white;  cursor: pointer;}.tab-control li:hover{  background-color:#7b7474}.tab-control a{  display:inline-block;  width:100%;  height:100%;  line-height:100%;  text-align:center;  text-decoration: none;}.tab-control a::after{  content:"";  display:inline-block;  height:100%;  vertical-align:middle;}.tab-content .item:target{  z-index:1;  background-color:yellow;}

登录后复制

item使用绝对定位,然后使用:target修改元素z-index达到切换效果(其实也可以通过控制元素的display来达到切换效果)

(2)针对布局二:

 

立即学习“前端免费学习笔记(深入)”;

登录后复制

 

立即学习“前端免费学习笔记(深入)”;

ul,li,p {  margin: 0;  padding: 0;  list-style: none;}.container {  width: 400px;  height: 300px;  background-color: silver;  border: 1px solid silver;}.container ul {  width: 100%;  height: 100%;  overflow: hidden;}.container .item {  float: left;  width: 25%;  height: 100%;  background-color: white;}.container .item .title {  line-height: 40px;  border: 1px solid silver;  box-sizing: border-box;  text-align: center;  cursor: pointer;}.container .item a {  display:inline-block;  width:100%;  height:100%;  text-decoration: none;}.container .item .content {  width: 400%;  height: 100%;  background-color: yellow;}.ml1 {  margin-left: -100%;}.ml2 {  margin-left: -200%;}.ml3 {  margin-left: -300%;}.active {  position: relative;  z-index: 1}.container .item:target {  position: relative;  z-index: 1}.container .item:target .title {  border-bottom: none;  background-color: yellow;}

登录后复制

 

立即学习“前端免费学习笔记(深入)”;

2、hover实现

(1)针对布局一:

无法简单的通过CSS实现

(2)针对布局二:

 

立即学习“前端免费学习笔记(深入)”;

  • 1

    1

  • 2

    2

  • 3

    3

  • 4

    4

登录后复制登录后复制

 

立即学习“前端免费学习笔记(深入)”;

ul,li,p{  margin:0;  padding:0;  list-style:none;}.container{  width:400px;  height:300px;  background-color:silver;  border:1px solid silver;}.container ul{  width:100%;  height:100%;  overflow:hidden;}.container .item{  float:left;  width:25%;  height:100%;  background-color:white;}.container .item .title{  line-height:40px;  border:1px solid silver;  box-sizing:border-box;  text-align:center;  cursor:pointer;}.container .item .content{  width:400%;  height:100%;  background-color:yellow;}.ml1{  margin-left:-100%;}.ml2{  margin-left:-200%;}.ml3{  margin-left:-300%;}.active{  position:relative;  z-index:1}.container .item:hover{  position:relative;  z-index:1}.container .item:hover .title{  border-bottom:none;  background-color:yellow;}

登录后复制登录后复制

3、label与:checked实现

(1)针对布局一:

 

立即学习“前端免费学习笔记(深入)”;

内容1

内容2

内容3

内容4

登录后复制

 

立即学习“前端免费学习笔记(深入)”;

ul,li {  margin: 0;  padding: 0;  list-style: none;}.container {  width: 400px;  height: 300px;  background-color: silver;}.tab-content {  position: relative;  width: 100%;  height: 80%;  overflow: hidden;}input {  margin: 0;  width: 0;}.tab-content .item {  position: absolute;  left: 0;  top: 0;  width: 100%;  height: 100%;}.tab-control {  width: 100%;  height: 20%;}.tab-control ul {  height: 100%;}.tab-control li {  width: 25%;  height: 100%;  float: left;  border: 1px solid silver;  box-sizing: border-box;  background-color: white;}.tab-control li:hover {  background-color: #7b7474}.tab-control label {  display: inline-block;  width: 100%;  height: 100%;  line-height: 100%;  text-align: center;  text-decoration: none;  cursor: pointer;}.tab-control label::after {  content: "";  display: inline-block;  height: 100%;  vertical-align: middle;}.tab-content .radio-item{  display:none;}.tab-content .radio-item:checked+.item {  z-index: 1;  background-color: yellow;}

登录后复制

利用css :checked与+(选择紧接在另一个元素后的元素,而且二者有相同的父元素)选择符。

(2)针对布局二:

 

立即学习“前端免费学习笔记(深入)”;

  • 1

  • 2

  • 3

  • 4

登录后复制

 

立即学习“前端免费学习笔记(深入)”;

ul,li,p{  margin:0;  padding:0;  list-style:none;}.container{  width:400px;  height:300px;  background-color:silver;  border:1px solid silver;}.container ul{  width:100%;  height:100%;  overflow:hidden;}.container .item{  float:left;  width:25%;  height:100%;  background-color:white;}.container .item .title{  display:inline-block;  width:100%;  line-height:40px;  border:1px solid silver;  box-sizing:border-box;  text-align:center;  cursor:pointer;}.container .item .content{  position:relative;  width:400%;  height:100%;  background-color:yellow;}.ml1{  margin-left:-100%;}.ml2{  margin-left:-200%;}.ml3{  margin-left:-300%;}.radio-item{  display:none;}.radio-item:checked~.title{  background-color:yellow;  border-bottom:none;}.radio-item:checked~.content{  background-color:yellow;  z-index:1;}

登录后复制

相关推荐:

CSS 利用table实现五种常用布局的方法示例_CSS教程_CSS_网页制作

CSS 利用table实现五种常用布局的方法示例_CSS教程_CSS_网页制作

CSS 利用table实现五种常用布局的方法示例_CSS教程_CSS_网页制作

以上就是关于实现CSS Tab布局的简单实例的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2901089.html

(0)
上一篇 2025年3月11日 00:05:56
下一篇 2025年3月11日 00:06:03

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 详解css3和伪元素实现鼠标移入时下划线向两边展开

    本文主要介绍了利用css3+伪元素实现鼠标移入时下划线向两边展开效果的相关资料,文中先进行了详细的介绍,方便大家理解,而后给出了完整的实例代码让大家可以参考学习,需要的朋友们下面来一起学习学习吧。希望能帮助到大。 先来看看效果图: 实现思路…

    2025年3月11日
    000
  • 实例讲解CSS3仿微信聊天气泡的方法

    我们知道qq上聊天气泡有很多,微信呢只有很简单的一种,本文主要介绍了css3 仿微信聊天小气泡实例代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能帮助到大家。 现在就教大家怎么用css3制作一个和微信聊天界面一样的页面。 首先…

    2025年3月11日
    200
  • CSS3实现头像旋转效果实例分享

    本文主要介绍了css3实现头像旋转效果,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧,希望能帮助到大家。 鼠标未放上效果: 鼠标放上之后旋转效果: 立即学习“前端免费学习笔记(深入)”; transition:…

    2025年3月11日
    200
  • 实例详解用React加CSS3实现微信拆红包动画效果

    本文主要介绍了用react加css3实现微信拆红包动画效果,微信红包曾经引爆过一系列的营销热潮,相信大家对于这种红包形式并不陌生,这里本着娱乐至上的精神用react简单地实现了拆红包的动画效果,希望能帮助到大家。 用CSS3绘制红包 .re…

    2025年3月11日 编程技术
    200
  • css background-attachment属性基础介绍

    本文主要为大家介绍了在css中,使用背景附件属性background-attachment可以设置背景图像是随对象滚动还是固定不动,需要的朋友可以参考下,希望能帮助大家。 一、background-attachment属性 在CSS中,使用…

    2025年3月11日
    200
  • 利用css隐藏input的光标方法

    如何在不影响操作的情况下,把input的光标隐藏了?在网上搜索了很多方式:用p模拟,设置readonly,设置disabled,设置自动blur等等方式,发现都不能满足需求,于是最后终于找到了一种完美的方法。本文主要给大家介绍了关于如何利用…

    2025年3月11日
    200
  • 五种CSS 利用table实现常用布局的方法

    本文主要介绍了css 利用table实现五种常用布局的方法示例的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧,希望能帮助到大家更好的掌握css 利用table实现常用布局。 布局一: 效果: 代码: …

    2025年3月11日 编程技术
    200
  • 实例详解CSS Flexbox的具体用法

    flexbox是一个强大而灵活的布局,本文主要介绍了css flexbox的具体用法详解的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧,希望能帮助到大家。 一、Flexbox简介 Flexbox布局(…

    2025年3月11日 编程技术
    200
  • CSS图片大小不固定的居中方法

    css是前端开发必不可少的一门语言,本文主要介绍了css居中实例之大小不固定的图片居中方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧,希望能帮助到大家。 1.利用table-cell实现垂直居中     […

    2025年3月11日
    200
  • 详解css3自定义滚动条样式写法

    本文我们主要和大家分享css3自定义滚动条样式写法,先简单介绍一下各个属性,文章会向大家展示四种效果。希望能帮助到大家。 ::-webkit-scrollbar       :滚动条整体部分,其中的属性有width,height,backg…

    2025年3月11日 编程技术
    200

发表回复

登录后才能评论