亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > CSS > 正文

CSS實現Tab布局的簡單實例(必看)

2024-07-11 08:58:20
字體:
來源:轉載
供稿:網友

一、布局方式

1、內容與tab分離

 

<div class="container">   <div class="tab-content">     <div id="item1" class="item">內容1</div>     <div id="item2" class="item">內容2</div>     <div id="item3" class="item">內容3</div>     <div id="item4" class="item">內容4</div>   </div>   <div class="tab-control">     <ul>        <li><a href="#item1">內容1</a></li>        <li><a href="#item2">內容2</a></li>        <li><a href="#item3">內容3</a></li>        <li><a href="#item4">內容4</a></li>     </ul>   </div></div>

 

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;}

2、內容與tab一體 

 

<div class="container">   <ul>     <li class="item active">       <p class="title">1</p>       <p class="content">1</p>     </li>     <li class="item">       <p class="title">2</p>       <p class="content ml1">2</p>     </li>     <li class="item">       <p class="title">3</p>       <p class="content ml2">3</p>     </li>     <li class="item">       <p class="title">4</p>       <p class="content ml3">4</p>     </li>   </ul></div>

 

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;}

利用負margin,將內容區對齊,然后內容去添加背景色,避免不同tab對應的區域透視重疊。

二、CSS實現交互

1、錨點實現(target)

(1)針對布局一:item從上往下排列,父元素tab-content加上overflow:hidden。利用錨點,點擊不同a標簽的時候,具有對應ID的item會切換到tab-content的視圖中,然后利用hover給tab按鈕加上切換樣式。

 

<div class="container">   <div class="tab-content">     <div id="item1" class="item">內容1</div>     <div id="item2" class="item">內容2</div>     <div id="item3" class="item">內容3</div>     <div id="item4" class="item">內容4</div>   </div>   <div class="tab-control">     <ul>        <li><a href="#item1">內容1</a></li>        <li><a href="#item2">內容2</a></li>        <li><a href="#item3">內容3</a></li>        <li><a href="#item4">內容4</a></li>     </ul>   </div></div>

 

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)針對布局二:

 

<div class="container">   <ul>     <li class="item active" id="item1">       <p class="title"><a href="#item1">1</a></p>       <p class="content">1</p>     </li>     <li class="item" id="item2">       <p class="title"><a href="#item2">2</a></p>       <p class="content ml1">2</p>     </li>     <li class="item" id="item3">       <p class="title"><a href="#item3">3</a></p>       <p class="content ml2">3</p>     </li>     <li class="item" id="item4">       <p class="title"><a href="#item4">4</a></p>       <p class="content ml3">4</p>     </li>   </ul></div>

 

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)針對布局二:

 

<div class="container">   <ul>     <li class="item active">       <p class="title">1</p>       <p class="content">1</p>     </li>     <li class="item">       <p class="title">2</p>       <p class="content ml1">2</p>     </li>     <li class="item">       <p class="title">3</p>       <p class="content ml2">3</p>     </li>     <li class="item">       <p class="title">4</p>       <p class="content ml3">4</p>     </li>   </ul></div>

 

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)針對布局一:

 

<div class="container">  <div class="tab-content">    <input type="radio" name="item" class="radio-item" id="item1" checked/>    <div class="item">內容1</div>    <input type="radio" name="item" class="radio-item" id="item2" />    <div class="item">內容2</div>    <input type="radio" name="item" class="radio-item" id="item3" />    <div class="item">內容3</div>    <input type="radio" name="item" class="radio-item" id="item4" />    <div class="item">內容4</div>  </div>  <div class="tab-control">    <ul>      <li><label for="item1">內容1</label></li>      <li><label for="item2">內容2</label></li>      <li><label for="item3">內容3</label></li>      <li><label for="item4">內容4</label></li>    </ul>  </div></div>

 

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)針對布局二:

 

<div class="container">   <ul>     <li class="item active">       <input type="radio" name="item" class="radio-item" id="item1" checked/>       <label class="title" for="item1">1</label>       <p class="content">1</p>     </li>     <li class="item">       <input type="radio" name="item" class="radio-item" id="item2" />       <label class="title" for="item2">2</label>       <p class="content ml1">2</p>     </li>     <li class="item">       <input type="radio" name="item" class="radio-item" id="item3" />       <label class="title" for="item3">3</label>       <p class="content ml2">3</p>     </li>     <li class="item">       <input type="radio" name="item" class="radio-item" id="item4" />       <label class="title" for="item4">4</label>       <p class="content ml3">4</p>     </li>   </ul></div>

 

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布局的簡單實例(必看)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧洲成人免费aa| 国产精品三级久久久久久电影| 丝袜亚洲另类欧美重口| 亚洲精品v天堂中文字幕| 丝袜亚洲另类欧美重口| 久色乳综合思思在线视频| 亚洲第一网中文字幕| 亚洲一区中文字幕| 精品久久久999| 国产精品女人久久久久久| 欧美在线www| 欧美日本在线视频中文字字幕| 日韩一区视频在线| 国产一区二区三区在线播放免费观看| 欧美巨乳美女视频| 亚洲电影免费观看高清完整版| 久久中文字幕在线视频| 美女啪啪无遮挡免费久久网站| 国产久一一精品| 亚洲国产一区自拍| 91香蕉国产在线观看| 51ⅴ精品国产91久久久久久| 国产精品国模在线| 国产成人一区三区| 久久成人精品视频| 欧美性色19p| 国产免费一区二区三区香蕉精| 在线观看中文字幕亚洲| 亚洲黄色在线看| 夜夜躁日日躁狠狠久久88av| 91精品视频在线播放| 动漫精品一区二区| 亚洲第一页在线| 国产一区二区丝袜高跟鞋图片| 国产美女精品视频| 久久天天躁狠狠躁夜夜av| 国产精品白嫩美女在线观看| www.久久草.com| 91亚洲国产成人久久精品网站| 亚洲大胆人体视频| 国产欧美亚洲视频| 欧美大尺度在线观看| 欧美激情在线有限公司| 欧美色视频日本高清在线观看| www.欧美视频| 久久久精品视频在线观看| 日本一区二三区好的精华液| 亚洲欧美日韩天堂一区二区| 亚洲女人天堂成人av在线| 久久国产精品视频| 奇门遁甲1982国语版免费观看高清| 精品一区二区三区三区| 久久久久久国产免费| 57pao国产成人免费| 欧美久久精品一级黑人c片| 欧美福利在线观看| 成人免费看吃奶视频网站| 全色精品综合影院| 日韩av电影中文字幕| 92裸体在线视频网站| 国产精品成人一区二区三区吃奶| 亚洲第一中文字幕| 中文字幕在线国产精品| 亚洲国产又黄又爽女人高潮的| 亚洲一区二区久久久| 国产日产欧美a一级在线| 亚洲欧美制服综合另类| 国产精品久久久久久久久免费看| 久久久久久久久久久国产| 日韩黄色av网站| 精品视频偷偷看在线观看| 狠狠色狠色综合曰曰| 日韩精品视频在线免费观看| 97国产一区二区精品久久呦| 精品视频偷偷看在线观看| 日韩av免费观影| 日韩久久精品成人| 国产v综合v亚洲欧美久久| 欧美华人在线视频| 亚洲风情亚aⅴ在线发布| 国产精品视频精品| 亚洲激情视频网站| 亚洲欧洲高清在线| 亚洲午夜av电影| 欧美另类极品videosbest最新版本| 欧美性猛交xxxx偷拍洗澡| 国产一区二区三区在线看| 国产精品第一页在线| 久久视频在线观看免费| 一区二区在线视频播放| 亚洲乱码av中文一区二区| 国产精品久久久久久久美男| 国产精品免费久久久| 亚洲视频999| 亚洲成人黄色在线观看| 中文国产成人精品久久一| www.国产精品一二区| 少妇高潮久久77777| 国产精品揄拍一区二区| 国产亚洲欧美日韩美女| 欧美黑人性生活视频| 精品欧美aⅴ在线网站| 亚洲成人亚洲激情| 亚洲精品美女在线观看| 国产区亚洲区欧美区| 在线亚洲午夜片av大片| 亚洲第一天堂无码专区| 亚洲欧美在线播放| 亚洲欧美综合另类中字| 色妞色视频一区二区三区四区| 国产精品久久精品| 国产手机视频精品| 欧美制服第一页| 3344国产精品免费看| 亚洲嫩模很污视频| 国产精品高清免费在线观看| 中国日韩欧美久久久久久久久| 日韩成人在线观看| 亚洲欧洲自拍偷拍| 欧美精品激情blacked18| 中文国产成人精品久久一| 一区二区三区美女xx视频| 日韩视频在线免费观看| 在线播放日韩欧美| 成人妇女淫片aaaa视频| 欧美理论在线观看| 亚洲第一福利在线观看| 日韩精品在线视频| 97香蕉超级碰碰久久免费软件| 国产精品成人aaaaa网站| 久久久久久国产三级电影| 日本国产高清不卡| 在线观看视频99| 欧美激情亚洲国产| 国产91色在线|免| 欧美精品久久久久久久免费观看| 欧美在线免费看| 欧美极品美女视频网站在线观看免费| 91高潮在线观看| 欧美黑人性生活视频| 日韩av日韩在线观看| 国产视频精品在线| 亚洲国产精彩中文乱码av在线播放| 国产成人综合精品| 久久亚洲国产精品成人av秋霞| 一区二区三区黄色| 欧美一级黑人aaaaaaa做受| 久久综合五月天| 欧美在线精品免播放器视频| 日韩色av导航| 欧美视频在线观看免费网址| 欧美最猛性xxxxx亚洲精品| 精品国产一区二区三区在线观看| 91精品中国老女人| 少妇久久久久久| 亚洲天堂开心观看| 亚洲电影免费观看| 日韩hd视频在线观看| 亚洲国产欧美在线成人app| 国产精品一区二区久久国产| 欧美又大粗又爽又黄大片视频| 国产亚洲视频中文字幕视频| 亚洲欧美三级伦理| 国产91精品久|