|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
另外要叮嘱各位的是,抵御诱惑,ASP/PHP/JSP/.NET的对比也许会让你无所适从,你也许学了一半PHP,又开始打C#的主意,或者有人说JAVA很强,这个时候的你绝对不能动摇,哪怕你真想学。 Tab在以后的Web使用中长短经常见的,最大的优点在于可以充实的使用无限的空间来展现更多的内容。罕见的的Tab普通都是经由过程Javascript来完成,它的优点是天真和功效壮大。然而在某些情形下,假如仅仅需求一个复杂的内容切换时是可以思索利用纯CSS来完成的。本文次要引见两种纯CSS的完成计划:
1. 锚点 + :target;
2. 纯锚点;
这两种各有各长处,也有各自的局限性。
详细的Demo请检查这里
计划一: 锚点 + :target
CSS3中引入了一个新的伪类:target,当用户和页面停止某些交互时会触发,例若有以下的代码,当用户点击链接时,便会触发p元素的:target伪类。 <a href="#dest">Link to Dest</a>
<p id="dest">This is a new paragraph.</p>
计划一即是使用:target伪类来完成Tab切换。完成道理为:在页面加载的时分经由过程CSS埋没Tab绝对应的内容,同时在:target伪类中将Tab内容设置为可见。
HTML布局以下: <dl>
<dt class="tab-a first"><a href="#a">Tab A</a></dt>
<dd id="a" class="content-a">
Content A
</dd>
<dt class="tab-b"><a href="#b">Tab B</a></dt>
<dd id="b" class="content-b">
Content B
</dd>
<dt class="tab-c"><a href="#c">Tab C</a></dt>
<dd id="c" class="content-c">
Content C
</dd>
<dt class="tab-d"><a href="#d">Tab D</a></dt>
<dd id="d" class="content-d">
Content D
</dd>
</dl>
利用该布局的一个优点在于短少CSS时仍然可以明晰的浏览内容。
关头的CSS代码以下
dd{
padding: 5px;
/*埋没Tab的内容*/
display:none;
-moz-border-radius: 5px;
margin-top:20px
}
dd:target{
position: absolute;
/*显示Tab的内容*/
display:block;
}
/*给Tab和响应的内容设置不异的后台色*/
.tab-a,.content-a{
background: #CCFF00;
}
.tab-b,.content-b{
background: #CCFFFF;
}
.tab-c,.content-c{
background: #FFFF00;
}
.tab-d,.content-d{
background: #FFCCFF;
}
利用CSS计划的一个坏处在于不容易辨别哪一个Tab是以后选中的,一个复杂的体例是给响应的Tab和Tab内容设置不异的后台色,如许当Tab内容显示时,可以更明晰的分辨以后Tab。另外,因为是利用了CSS3中的选择符,因而今朝只能在Firefox、Safari、IE8等古代阅读器下利用。
计划二: 纯锚点
计划二的道理很复杂,在大多半阅读器下,当点击锚点链接时,锚点对应的内容会主动跳到可视局限之内。依据该道理,将Tab的一切内容放到一个固定高度的容器中,而且设置容器的overflow为hidden,另外每一个Tab内容的高度需求与容器坚持分歧。在该布局下,当点击锚点链接时对应的内容会主动跳转到可视局限之内容,即容器内。
详细的HTML布局以下: <ul id="tab_nv">
<li class="tab-a"><a href="#a2">Tab A</a></li>
<li class="tab-b"><a href="#b2">Tab B</a></li>
<li class="tab-c"><a href="#c2">Tab C</a></li>
<li class="tab-d"><a href="#d2">Tab D</a></li>
</ul>
<div id="tab_content">
<div id="a2" class="content content-a">
Content A
</div>
<div id="b2" class="content content-b">
Content B
</div>
<div id="c2" class="content content-c">
Content C
</div>
<div id="d2" class="content content-d">
Content D
</div>
</div>
因为和计划一的道理纷歧样,此处的HTML布局也只能利用Tab和内容分别的布局,利用该布局的一个成绩在于当CSS缺掉的情形下没法明晰的浏览内容。
关头的CSS代码以下: /*给Tab Content容器设置高度*/
#tab_content{
height: 190px;
overflow: hidden;
}
/*给每一个Tab Content定高度,需求与容器坚持分歧*/
#tab_content .content{
padding: 5px;
-moz-border-radius: 5px;
height: 190px;
overflow: hidden;
}
与计划逐一样,这里也经由过程给Tab和对应内容设置不异后台色来处理选中辨认成绩。
总结
1. 纯CSS完成的Tab受限良多,好比计划二中需求给每一个Tab Content设置不异的高度。
2. 没法无效的标识以后选中的Tab,本文是经由过程设置不异后台色做辨别,在良多情形下纷歧定合用。
3. 两个计划都存在兼容性成绩,计划一利用了CSS3的选择符,受限于CSS的完成;而计划二听说在Opera下不灵。
4. 计划一中,当点击其他会触发:target的锚点(或产生相似交互)时,Tab Content会埋没。
<P style="TEXT-INDENT: 2em">
刚开始因为习惯于ASP格式的写法,总是在这些方面出现问题,自己还总是找不到问题所在,这就提醒了自己,在写代码的时候一定要认真,不能粗心地老是少个“;”或者字母大小写不分,要不然很可能找半天都找不到错误。 |
|