我们的设计越来越追求一种简洁的风格,希望在有限的空间内展示更多的内容。与此同时我们发现一些问题,内容的简单排列总使页面很长。滚屏很多才能将显示的内容布局完毕。YAHOO与网易率先应用了标签切换的布局方式,打破了常规布局的局限性,在相同尺寸的区域内,可以放置更多的内容。我们只需要点击不同的选项卡或链接就能展开内容,这并不需要打开新的网页,只是在同一页内完成。
一、标签切换总体的实现思路:
实现这种标签切换的布局有多种方式,也流传着各种不同的代码,我们应用DIV CSS进行布局,首先来整理一下思路,如何实现这样的标签切换效果:
1、首先要放置标签切换的容器,可以是选项卡形式,也可以是链接的形式;
2、放置具体的内容,并默认显示其中的一个为显示状态。其它的内容则进行隐藏;
3、当用户点击选项卡或链接时,应用javascript切换到指定的层进行显示,而其它的内容层进行隐藏;
4、进行后期深入,例如,去除链接虚线与内容层图文的美化等。
我们看最终本实例的效果图片:
本实例所用到的两张背景图片如下:
二、根据上面的思路我们开始整理HTML代码。我们作了如下规划:
Example Source Code []
<div class="woaicss">
<ul class="woaicss_title woaicss_title_bg1" id="woaicsstitle">
</ul>
<div class="woaicss_con" id="woaicss_con1" style="display:block;">
</div>
<div class="woaicss_con" id="woaicss_con2" style="display:none;">
</div>
<div class="woaicss_con" id="woaicss_con3" style="display:none;">
</div>
<div class="woaicss_con" id="woaicss_con4" style="display:none;">
</div>
</div>
1、我们布置一个总体的容器,并应用类woaicss。
2、设置一个无序列表UL作为选项卡或链接的容器(下面具体介绍)。
3、我们分别设置了四个层,作为内容层(我们假想有四个切换)。请非凡注重这四个层均应用了类woaicss_con。与此同时为他们分别指定了不同的id。这是为了让javascript可以进行控制。我们设置第一个层的样式为块元素,即显示出该内容层。而其它三层均进行了隐藏。
三、我们开始进一步完善HTML代码。无序列表UL增加一些链接:
Example Source Code []
<ul class="woaicss_title woaicss_title_bg1" id="woaicsstitle">
<li><a href="javascript:void(0)" onclick="javascript:woaicssq(1)"></a></li>
<li><a href="javascript:void(0)" onclick="javascript:woaicssq(2)">Div CSS教程</a></li>
<li><a href="javascript:void(0)" onclick="javascript:woaicssq(3)">CSS布局实例</a></li>
<li><a href="javascript:void(0)" onclick="javascript:woaicssq(4)">WEB标准化</a></li>
</ul>
1、我们为无序列表UL应用了两个类woaicss_title、woaicss_title_bg1,第一个类可以对UL及LI、链接进行整体的外观控制。以实现整体美化效果。我们也为无序列表UL指定了一个id为woaicsstitle,目的在于可以应用javascript进行样式控制。
2、我们增加了四个链接,并对链接目标指定为:javascript:void(0)。我们应该了解,当链接为“#”时,浏览器会回到页面顶部。而此处我们并不希望看到这样的结果,因为在很多情况下,我们的切换框并不一定是在网页的第一屏,假如点击链接回到顶部,访客就不会立即看到内容层所出现的变化。失去了制作标签切换效果的意义。
3、我们为链接设置了onclick动作avascript:woaicssq(x)。我们在这里向javascript传递参数,以执行不同的脚本,实现切换的效果。
四、开始进行javascript脚本的编写:
Example Source Code []
function woaicssq(num){
for(var id = 1;id<=4;id )
{
var MrJin="woaicss_con" id;
if(id==num)
document.getElementById(MrJin).style.display="block";
else
document.getElementById(MrJin).style.display="none";
}
if(num==1)
document.getElementById("woaicsstitle").className="woaicss_title woaicss_title_bg1";
if(num==2)
document.getElementById("woaicsstitle").className="woaicss_title woaicss_title_bg2";
if(num==3)
document.getElementById("woaicsstitle").className="woaicss_title woaicss_title_bg3";
if(num==4)
document.getElementById("woaicsstitle").className="woaicss_title woaicss_title_bg4";
}
javascript脚本工作原理作简要的说明:
(由于本站仅针对CSS进行讨论,这里对此脚本不作具体分析)
1、设置函数woaicssq,并从标签切换的链接中获取参数,如:javascript:woaicssq(2)
2、声明变量id为数值为1并小于等于4。这是我们四个内容层的数值。
3、声明变量MrJin为"woaicss_con" id; (请注重我们在第一步骤所设置内容层的id,如:id="woaicss_con2"。)当id为所指定的数值时,则该层的属性为display="block";。否则层的属性为display="none"。即实现了内容层显示与隐藏的切换功能。
4、当变量id为1-4其中的某一个数值是,对id为woaicsstitle的容器进行样式定义,如:woaicss_title woaicss_title_bg3。这样我们就可以通过不同的class类,对切换链接进行不同的样式定义,当某一层显示的时候,我们可以对该层所对应的链接作出一些指示。如选项卡的突出状态等。
五、开始CSS的编写:
Example Source Code []