DIVCSS實例教程:利用一張背景圖片實現(xiàn)的簡單CSS導(dǎo)航菜單_Div+CSS教程
教程Tag:暫無Tag,歡迎添加,賺取U幣!
今天介紹的這款簡單非常簡單,利用一張背景圖片來實現(xiàn)菜單的懸停狀態(tài)。我們看下面的圖片:

僅這一張圖片,我們實現(xiàn)一個橫行CSS菜單。并設(shè)置它們的懸停效果。我們該如何做呢?看下面的圖片:

這是一個示意圖。最底層是ul,這是一個容器,我們將列表項li全部置入其中。為了方便說明,示意圖中僅畫了一個li。實際此例中有六個li,全部向左浮動,實現(xiàn)橫行排列。在li上面還有鏈接a標(biāo)簽。
我們首先整理XHTML代碼:
示例代碼 [www.hl5o.cn]
<ul id="mini_nav">
<li class="nav1"><a href="http://www.hl5o.cn/" title="財經(jīng)">財經(jīng)</a></li>
<li class="nav2"><a href="http://www.hl5o.cn/" title="商業(yè)">商業(yè)</a></li>
<li class="nav3"><a href="http://www.hl5o.cn/" title="治理">治理</a></li>
<li class="nav4"><a href="http://www.hl5o.cn/" title="領(lǐng)袖">領(lǐng)袖</a></li>
<li class="nav5"><a href="http://www.hl5o.cn/" title="協(xié)會">協(xié)會</a></li>
<li class="nav6"><a href="http://www.hl5o.cn/" title="博客">博客</a></li>
</ul>
<li class="nav1"><a href="http://www.hl5o.cn/" title="財經(jīng)">財經(jīng)</a></li>
<li class="nav2"><a href="http://www.hl5o.cn/" title="商業(yè)">商業(yè)</a></li>
<li class="nav3"><a href="http://www.hl5o.cn/" title="治理">治理</a></li>
<li class="nav4"><a href="http://www.hl5o.cn/" title="領(lǐng)袖">領(lǐng)袖</a></li>
<li class="nav5"><a href="http://www.hl5o.cn/" title="協(xié)會">協(xié)會</a></li>
<li class="nav6"><a href="http://www.hl5o.cn/" title="博客">博客</a></li>
</ul>
我們著手寫CSS前,先結(jié)合上面的示意圖整理一下思路:
1、首先需要讓ul居中,然后讓nav成為ul的背景圖片。這樣就可以簡化編碼,不必給每一個li或a再定義不同的背景圖片及其定位。
2、定義列表項li的寬度與高度,并向左浮動。實現(xiàn)列表項的橫向排列,組成一個橫向的菜單格局。
3、定義列表項內(nèi)部的鏈接a元素為塊元素。并給a:hover一個背景圖片,但不給他任何定位信息。
4、根據(jù)nav1~nav6分別定義a:hover狀態(tài)下,背景圖片的定位。
5、利用padding移除鏈接a元素的文字。使得在CSS有效時文字不可見,若出現(xiàn)CSS加載失敗或其它設(shè)備瀏覽時,鏈接同樣有效。
我們開始著手CSS編寫:
示例代碼 [www.hl5o.cn]
* {margin:0; padding:0; font-size:12; list-style-type:none; }
#mini_nav {width:390px; height:38px; margin:50px auto; background:url(nav.png) no-repeat 0 0;}
#mini_nav li {width:65px; height:38px; float:left;}
#mini_nav li a {display:block; width:65px; height:38px;}
#mini_nav li a:hover {background:url(nav.png) no-repeat;}
#mini_nav {width:390px; height:38px; margin:50px auto; background:url(nav.png) no-repeat 0 0;}
#mini_nav li {width:65px; height:38px; float:left;}
#mini_nav li a {display:block; width:65px; height:38px;}
#mini_nav li a:hover {background:url(nav.png) no-repeat;}
設(shè)置總體布局聲明,外邊距與內(nèi)邊距均為零,文字大小為12px,列表項預(yù)調(diào)標(biāo)記為無(去掉列表項前面的小黑點)。
設(shè)置ID為mini_nav的UL寬度與高度,上下邊距為50px,左右邊距為auto,實現(xiàn)水平居中對齊。設(shè)計背景圖片為nav.png,定位于:0 0。
設(shè)置UL中的LI的樣式,寬度與高度,向左浮動。
設(shè)置LI中鏈接A元素的樣式,首先將A元素轉(zhuǎn)換為塊元素,并設(shè)置其寬與高。
設(shè)置鏈接A元素的縣停樣式,定義背景圖片nav.png,重復(fù)方式為不重復(fù),不給出背景圖片的定位信息。
此時我們可以看到的頁面效果如下:

但這時候還不能實現(xiàn)任何懸停交互效果,而且鏈接文字而位于我們的神覺范圍內(nèi)。我們繼續(xù)編寫CSS代碼:
示例代碼 [www.hl5o.cn]
#mini_nav li.nav1 a:hover {background-position:0 -38px;}
#mini_nav li.nav2 a:hover {background-position:-65px -38px;}
#mini_nav li.nav3 a:hover {background-position:-130px -38px;}
#mini_nav li.nav4 a:hover {background-position:-195px -38px;}
#mini_nav li.nav5 a:hover {background-position:-260px -38px;}
#mini_nav li.nav6 a:hover {background-position:-325px -38px;}
#mini_nav li.nav2 a:hover {background-position:-65px -38px;}
#mini_nav li.nav3 a:hover {background-position:-130px -38px;}
#mini_nav li.nav4 a:hover {background-position:-195px -38px;}
#mini_nav li.nav5 a:hover {background-position:-260px -38px;}
#mini_nav li.nav6 a:hover {background-position:-325px -38px;}
這一段很相類,我們給不同的鏈接(即nav1~nav6)設(shè)置了鼠標(biāo)懸停時的定位坐標(biāo)。
我們給前面的LI中鏈接A元素增加以下代碼:
示例代碼 [www.hl5o.cn]
padding-top:40px; overflow:hidden;
上部的內(nèi)邊距為40px。溢出為隱藏。我們將鏈接文字增加上部的內(nèi)邊距,從而推到了下面,不可見的地方,為了使這樣的方法成功,我們必須設(shè)置溢出為隱藏。
相關(guān)Div+CSS教程:
- DIV+CSS設(shè)計的誤區(qū)
- CSS基礎(chǔ):常用CSS英文字體介紹
- IE6和IE7中border邊框斷線現(xiàn)象
- border:none;與border:0;的有什么不同?
- div+css下js對聯(lián)廣告不隨屏幕滾動的解決方法
- HTML元素的ID和Name屬性的區(qū)別
- divcss教程:深入了解css的行高Line Height屬性
- CSS文檔流,塊級元素和內(nèi)聯(lián)元素
- 5個你該知道的CSS3新技術(shù)
- 用正則表達式替換a標(biāo)記href值
- 30個優(yōu)秀的CSS導(dǎo)航和按鈕設(shè)計教程
- css中px和em有什么區(qū)別
- 相關(guān)鏈接:
- 教程說明:
Div+CSS教程-DIVCSS實例教程:利用一張背景圖片實現(xiàn)的簡單CSS導(dǎo)航菜單
。