CSS实现Tab布局实例展示

下面小编就为大家带来一篇css实现tab布局的简单实例(必看)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

一、布局方式

1、内容与tab分离

 

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

   

     

内容1

     

内容2

     

内容3

     

内容4

      

     

登录后复制登录后复制        内容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

      

     

登录后复制登录后复制        内容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)针对布局二:

 

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

   

登录后复制登录后复制登录后复制登录后复制            

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 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实现Tab布局实例展示的详细内容,更多请关注【创想鸟】其它相关文章!

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

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

(0)
上一篇 2025年3月11日 01:44:55
下一篇 2025年3月11日 01:45:02

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

相关推荐

  • CSS中Fonts属性的实例详解

    font-weight: normal; serif和sans-serif字体之间的区别   在计算机屏幕上,sans-serif字体被认为是比serif字体容易阅读 CSS字型 在CSS中,有两种类型的字体系列名称: 通用字体系列 &#8…

    2025年3月11日
    200
  • CSS 列表样式的实例讲解

    margin: 0px; CSS 列表 css列表css列表作用如下: 设置不同的列表项标记为有序列表 设置不同的列表项标记为无序列表 设置列表项标记为图像 列表 在HTML中,有两种类型的列表: 立即学习“前端免费学习笔记(深入)”; 无…

    编程技术 2025年3月11日
    200
  • 对CSS中Table的相关介绍

    表格边框 指定css表格边框,使用border属性。 下面的例子指定了一个表格的Th和TD元素的黑色边框: 实例 table, th, td{border: 1px solid black;} 登录后复制 请注意,在上面的例子中的表格有双边…

    编程技术 2025年3月11日
    200
  • 对CSS 框模型的介绍以及实例教程

    margin: 20px 0px; CSS 框模型(Box Model) 所有html元素可以看作盒子,在css中,”box model”这一术语是用来设计和布局时使用。 CSS盒模型本质上是一个盒子,封装周围的HT…

    2025年3月11日
    200
  • 介绍CSS外边距是如何使用的

    css margin(margin)margin定义元素周围的空间。 Margin margin清除周围的元素(外边框)的区域。margin没有背景颜色,是完全透明的 margin可以单独改变元素的上,下,左,右边距。也可以一次改变所有的属…

    编程技术 2025年3月11日
    200
  • css让容器水平垂直居中的7种方式

    这篇文章主要为大家详细介绍了css让容器水平垂直居中的7种方式,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 这种css布局平时用的比较多,也是面试题常出的一个题,网上一搜一大丢,不过还是想自己总结一下。这种方法比较多,本文只总结其中的…

    编程技术 2025年3月11日
    200
  • 利用CSS代码实现立方体360度旋转效果实例展示

    这篇文章通过实例代码给大家介绍了利用css实现立方体360度旋转效果的方法,实现后的效果非常炫酷,而且实现的代码非常简单,对大家的理解和学习很有帮助,有需要的朋友们下面来一起看看吧。 静态效果图如下: 示例代码: 代码如下: nbsp;ht…

    2025年3月11日
    200
  • 如何利用CSS技术实现下拉框酷炫的特效

    这篇文章给大家介绍的是一个利用css实现的酷炫的下拉框,实现后效果真的非常不错,文中给出了详细实现过程和示例代码,感兴趣的朋友们下面来一起看看吧。 首先来看看要实现的效果图 想要制作这么一个效果还是比较麻烦的,但是代码并不难理解。 首先,来…

    2025年3月11日
    200
  • 利用纯CSS自定义Checkbox和Radio的样式示例代码

    大家应该都知道checkbox和radio这两个控件比较特殊,因为它在不同平台的拥有不同的展示。所以这篇文章就来给大家介绍如何利用css3的一些属性来实现自定义checkbox和radio样式,有需要的朋友们可以参考借鉴,下面来一起看看吧。…

    2025年3月11日 编程技术
    200
  • 详解CSS中的display:flex||inline-flex属性

    这篇文章主要给大家介绍了css中的display:flex和display:inline-flex属性,文中分别通过两段实例代码给大家介绍了display:flex和display:inline-flex的使用效果,感兴趣的朋友们可以参考借…

    2025年3月11日
    200

发表回复

登录后才能评论