首頁 > web前端 > css教學 > CSS標籤切換程式碼實例教學 比較漂亮_經驗交流

CSS標籤切換程式碼實例教學 比較漂亮_經驗交流

WBOY
發布: 2016-05-16 12:07:08
原創
1329 人瀏覽過

我們的設計越來越追求一種簡潔的風格,希望在有限的空間中展示更多的內容。同時我們發現一些問題,內容的簡單排列總是使頁面很長。滾屏很多才能將顯示的內容佈局完畢。 YAHOO與網易率先應用了標籤切換的佈局方式,打破了常規佈局的局限性,在相同尺寸的區域內,可以放置更多的內容。我們只需要點擊不同的選項卡或連結就能展開內容,這並不需要開啟新的網頁,只是在同一頁內完成。

一、標籤切換整體的實現思路:

  實現這種標籤切換的佈局有多種方式,也流傳著各種不同的程式碼,我們應用DIV CSS進行佈局,首先來整理一下思路,如何實現這樣的標籤切換效果:
  1、首先要放置標籤切換的容器,可以是選項卡形式,也可以是鏈結的形式;
  2、放置具體的內容,並預設顯示其中的一個為顯示狀態。其它的內容則進行隱藏;
  3、當使用者點擊選項卡或連結時,應用javascript切換到指定的層進行顯示,而其它的內容層進行隱藏;
  4、進行後期深入,例如,去除連結虛線與內容層圖文的美化等。

  我們看最終本實例的效果圖片:

二、根据上面的思路我们开始整理HTML代码。我们作了如下规划:

 


    

        

    

    

    

    

    

    

    

    
    

  1、我们布置一个总体的容器,并应用类woaicss。
  2、设置一个无序列表UL作为选项卡或链接的容器(下面详细介绍)。
  3、我们分别设置了四个层,作为内容层(我们假想有四个切换)。请特别注意这四个层均应用了类
woaicss_con。与此同时为他们分别指定了不同的id。这是为了让javascript可以进行控制。我们设置第
一个层的样式为块元素,即显示出该内容层。而其它三层均进行了隐藏。

三、我们开始进一步完善HTML代码。无序列表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脚本的编写:

 
    function woaicssq(num){
    for(var id = 1;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脚本工作原理作简要的说明:
  (由于本站52CSS.com仅针对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的编写:

 
* {
    list-style-type:none; 
    font-size:12px; 
    text-decoration:none; 
    margin:0; 
    padding:0;
}
  总体布局声明,去除列表项预设标记,设置文字大小为12px,去除文字装饰线,外边距与内边距均为
零。

 
.woaicss {
    width:438px; 
    height:300px; 
    overflow:hidden; 
    margin:50px auto;
}
  总体标签切换窗口的样式定义,宽高设置,溢出为隐藏,上下外边距为50px,左右为自动,实现水平
居中对齐。

 
.woaicss_title {
    width:438px; 
    height:30px; 
    background:#fff url(btn_bg.png) no-repeat; overflow:hidden;
}
  无序列表UL的样式,宽高设置,背景图片为btn_bg.png。

 
.woaicss_title li {
    display:block; 
    float:left; 
    margin:0 2px 0 0; 
    display:inline; 
    text-align:center;
}
  无序列表内列表项的样式,设置为块元素并应用向左的浮动,右侧外边距为2px。将列表项内联,文
字对齐方式为居中。

 
.woaicss_title li a {
    display:block; 
    width:90px; 
    heigth:30px; 
    line-height:34px; 
    color:#fff;
}
  列表项链接的样式,设置为块元素并指定了宽高,行高为34px,颜色为白色color:#fff;

 
.woaicss_title li a:hover {
    color:#f0f0f0; 
    text-decoration:underline;
}
  列表项链接的悬停样式,颜色为#f0f0f0,加下划线作为装饰线。

 
.woaicss_title_bg1 {background-position:0 0;}
.woaicss_title_bg2 {background-position:0 -30px;}
.woaicss_title_bg3 {background-position:0 -60px;}
.woaicss_title_bg4 {background-position:0 -90px;}
  此四个样式的定义请与步骤四javascript脚本进行联系。即在函数的值变化时,相应的对无序列表的
样式进行重新定义,我们在此处对背景图定位进行了调整,实现了选项卡片的突出状态。

 
.woaicss_con {
    display:block; 
    width:438px; 
    height:270px; 
    background:url(con_bg.png) no-repeat 0 0; overflow:hidden;
}
  内容层的样式定义,指定宽高,并设置背景图片con_bg.png。52CSS.com请您特别注意,这里的背景
图片与无序列表UL的背景图片应该是无缝结合。即从外观上它们两者是一个整体。

六、内容充实:

  我们为内容层填充一定的内容,并对其进行美化,例如:(仅说明其一,其它三个雷同。)

 
    
  我们充实的内容层为一个UL无序列表,我们对其进行样式定义:

 
.woaicss_con ul {
    width:418px; 
    height:250px; 
    margin:12px auto;
}
.woaicss_con li {
    width:418px; 
    line-height:30px; 
    margin:0 auto; 
    white-space:nowrap; 
    text-overflow:ellipsis; 
    overflow: hidden;
}
.woaicss_con li a {
    color:#03c;
}
.woaicss_con li a:hover {
    color:#069; 
    text-decoration:underline;
}
  此处不是本文重点,所以不再赘述,相关的知识请参考:>>> 52CSS.com关于列表UL制作的文章 
七:细节修饰

  我们这里的链接并未起到真正的URL转向的作用,仅是一个标签,所以我们可以将其虚线框去除,以
让我们的页面更加的工整与自然。将下面的代码另存为xuxian.htc文件:

 

<script> <BR>function hscfsy(){ <BR>this.blur(); <BR>} <BR></script>
  我們在CSS樣式中加入這句話程式碼:a {behavior:url(xuxian.htc)}
八:最終效果及舉一反三:

  我們最終即可實現了這樣的效果,您可以 >>> 點擊這裡查看 
  在我們的實現工作中可能會遇到另一種情況:
  我們需要實現當滑鼠劃過時進行切換,當滑鼠點擊時開啟對應內容的連結。
  我們將無序列表UL作如下修改即可實現:

 
    
  我們透過微的調整達到了這樣的效果,
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板