css利用一張背景圖制作導航菜單實現(xiàn)思路及代碼
發(fā)布時間:2013-03-28 16:43:37 作者:佚名
我要評論

利用一張背景圖片來實現(xiàn)菜單的懸停狀態(tài),沒有什么不可思議完全可以辦得到,僅這一張圖片,我們實現(xiàn)一個橫行CSS菜單。并設置它們的懸停效果,感興趣的朋友可以參考下哈,希望可以幫助到你
今天介紹的這款簡單非常簡單,利用一張背景圖片來實現(xiàn)菜單的懸停狀態(tài)。我們看下面的圖片:

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

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

但這時候還不能實現(xiàn)任何懸停交互效果,而且鏈接文字而位于我們的神覺范圍內。我們繼續(xù)編寫CSS代碼:
Example Source Code
復制代碼
代碼如下:#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;}
這一段很相類,我們給不同的鏈接(即nav1~nav6)設置了鼠標懸停時的定位坐標。
我們給前面的LI中鏈接A元素增加以下代碼:
Example Source Code [www.52css.com]
復制代碼
代碼如下:padding-top:40px; overflow:hidden;
上部的內邊距為40px。溢出為隱藏。我們將鏈接文字增加上部的內邊距,從而推到了下面,不可見的地方,為了使這樣的方法成功,我們必須設置溢出為隱藏。
相關文章
- 大家都知道,目前有很多瀏覽器無法實現(xiàn)背景裁切、背景透明度、背景變換和復雜背景定位等效果;那么這篇文章將詳細介紹了這幾種背景圖片的處理方法,需要了解的朋友可以參考下2012-12-24
- IE6下CSS背景圖片閃爍的Bug(ie6下的背景圖片緩存問題)2011-07-27
鏈接偽類(:hover)CSS背景圖片有閃動BUG的解決方法
IE6下鏈接偽類(:hover)CSS背景圖片有閃動BUG,主要原因ie會再一次請求這張圖片,或者說圖片沒被緩存。2011-04-28網頁CSS背景圖片使用的測試結果-CSS教程-網頁制作-網頁教學網
這篇文章主要講了CSS對背景圖片渲染效率的一些經驗和研究,在webjx.com中,還有著類似CSS效率的相關文章。 樹型結構豎線用樣式表(背景圖)來實現(xiàn),樣式表背景2008-10-17- 利用一張背景圖片來實現(xiàn)菜單的懸停狀態(tài),沒有什么不可思議完全可以辦得到,僅這一張圖片,我們實現(xiàn)一個橫行CSS菜單。并設置它們的懸停效果,感興趣的朋友可以參考下哈,希2013-03-28
純css實現(xiàn)的六邊形(蜂窩)導航效果(支持hover/兼容瀏覽器)
在之前的文章中曾經寫到過一篇“三角形變形記之純css實現(xiàn)的分布導航條效果”,其中用到了邊框實現(xiàn)三角形的效果。最近又折騰了一個六邊形的蜂窩效果給大家蹂躪。主要用到了2013-02-057款設計巧妙的css3飄帶狀3D立體效果的導航菜單和表單窗口
接下來向大家推薦7款設計巧妙的CSS3飄帶狀菜單和窗口,相當不錯的效果,很多都具有3D立體效果,看了相信你一定會喜歡的好了不多說,切入主題,希望本文可以幫助到你,提高2013-02-04不規(guī)則背景墻 CSS實現(xiàn)背景圖片不規(guī)則的導航菜單
一般情況下導航菜單的背景圖片都是比較有規(guī)則的,但是平時我們也會遇到很多背景圖片形狀不規(guī)則導航條比如但鼠標移上的時候,背景圖片不規(guī)則,本例只討論此種類型2013-01-02- W3cplus第二版本剛上線時,好多位朋友向我問起站上的分頁導航樣式是怎么制作;為了報答各位朋友一持對本站的大力支持,今天我特意把這個分頁導航的效果當作一個小教程來說。2012-12-24
- 不改變html結構,使導航菜單垂直水平居中這個問題應該如何解決呢?本文將詳細介紹,需要了解的朋友可以參考下2012-11-30