仿Windows下拉菜單,在網(wǎng)上是比較常見的,最初出現(xiàn)在微軟網(wǎng)站上,之后被大量效仿。 事實上制作這樣一個模擬菜單也并不是一件很困難的事,比如上面的例子代碼如下:
-------------------------------------------
<!-- 樣式部分 -->
<style type=text/css>
td,div { font: normal 12px 宋體; }
a { color: #F8F8F8; text-decoration: none; }
a:hover { color: #F8F8F8; text-decoration: underline; }
</style>
<!-- 實現(xiàn)部分 -->
<div style="background-color:#3366CC;width:68px;text-align:center;
padding:3px;border-bottom:1px solid #FFFFFF;z-index:1;"
onmouseover="myMenu.style.display='block'"
onmouseout="myMenu.style.display='none'">
<div style="position:absolute;width:0px;height:0px;overflow:visible;">
<div id=myMenu style="position:absolute;left:-10px;top:18px;display:none;
width:90px;background-color:#3366CC;padding:5px;text-align:left;">
<a href=#none>Link 1</a><br>
<a href=#none>Link 2</a><br>
<a href=#none>Link 3</a><br>
<a>...</a><br>
<a href=#none>Link N</a><br>
</div>
</div>
<a href=#none>菜單實例</a>
</div>
-----------------------------------
那么下面我們就由淺入深的對這種模擬菜單進行分析講解。
在講解之前,有一點需要說明的是:筆者在后面講解的代碼都基于當前的主流瀏覽器Microsoft Internet Explorer(即我們通常所說的IE)下的。筆者進行調(diào)試的瀏覽器是IE 5.01。另外,這樣一個菜單體現(xiàn)的是HTML/CSS/javascript的綜合應用,這里并不對一些細節(jié)進行詳細的講解,所以你至少應該有一點這方面的基礎。
基本原理其實,這個菜單實現(xiàn)的原理簡單的說就是:設置頁面元素的CSS屬性,對其進行定位并設置其是否可見,然后通過激發(fā)一定的事件,用javascript來動態(tài)的改變這些屬性。
看下面幾個CSS屬性:
position:定位類型,取值static/absolute/relative,其代表的含義簡單的說即無定位/絕對定位/相對定位;
left:距離左側(cè)的位置(具體的參照物與position的設置有關),單位為px或%;
top:距離頂部的位置(具體的參照物與position的設置有關),單位為px或%。
display:頁面元素的顯示狀態(tài),如取值block表示做為塊狀元素顯示,none則為不顯示,還有其他一些取值(如inline等)這里就不做詳解。
比如上例中的“div id=myMenu style="position:absolute;left:-10px;top:18px;display:none...”就是使用了這幾個屬性。
下面我們來看看如何用javascript來控制頁面元素的CSS屬性。
對HTML有一定了解的朋友一定清楚,幾乎所有的標記都有一個style屬性,通過設置這個屬性來設置該標記的CSS屬性(即CSS的內(nèi)聯(lián)用法)。在javascript中,每一個標記都被視為Document對象的一個子對象,而該標記的每一個HTML屬性也都是這個對象的屬性或子對象,style就是其中一個,通過用javascript控制style的屬性,就達到了動態(tài)改變頁面元素CSS屬性的目的。如上例中的“onmouseover="myMenu.style.display='block'"”就是一個很普通的用法,其中myMenu即我們所看到的“菜單”的ID,它原來的display為none,即不顯示,當鼠標移上去時,變?yōu)閎lock,即塊狀顯示。
另外要提的是:前面只說了如何實現(xiàn)定位、如何動態(tài)控制,那么定位的、控制的是什么元素呢?原則上來講,大部分塊狀元素(如div、table)都可以,而在IE中,div標記(注意,在一些非IE瀏覽器中,并不支持div標記)因其使用的靈活性和方便性而做為我們的選。上例使用的就是div標記。
好啦,基本的過程,上面大致已經(jīng)說完了。
初步實現(xiàn)模擬網(wǎng)頁下拉菜單中有幾個比較關鍵的CSS屬性:position、left、top、display,同時,他們也是style對象的屬性(請參見網(wǎng)頁菜單基本原理),今天我們就用這幾個基本屬性來實現(xiàn)一個簡單的網(wǎng)頁菜單。
首先請大家看筆者已經(jīng)做好的一個實例,然后我們對這個例子進行詳細代碼講解。
為大家閱讀方便,這里采用在代碼中加注釋的方式,紅色部分為注釋。
代碼如下:
------------------------------------------------------
<html>
<head>
<title>菜單實例</title>
<style type=text/css>
td,div { font: normal 12px 宋體; }
</style>
</head>
<body style="margin-left:12px;margin-top:16px;">
<table cellpadding=0 cellspacing=0 width=90% height=20 bgcolor=#CCCCCC>
<tr>
<td width=10> </td>
<td width=80 align=center onmouseover="menuShow(menu01)"
onmouseout="menuHide(menu01)">菜單實例</td>
<font color="red"><!--
上兩行為菜單中顯示的文字,注意這里面的事件觸發(fā):
onmouseover="menuShow(menu01)" 鼠標經(jīng)過時顯示菜單;
onmouseout="menuHide(menu01)" 鼠標移走時隱藏菜單。
參數(shù)menu01即要顯示的菜單的id,將在接下來的代碼中看到。
menuShow與menuHide分別為顯示、隱藏菜單方法,將在后面定義。
--></font>
<td> </td>
</tr>
</table>
<div style="position:absolute;top:36px;left:20px;display:none;
width:80px;height:100px;background-color:#DDDDDD;" id=menu01
onmouseover="menuShow(this)" onmouseout="menuHide(this)">
<font color="red"><!--
以上三行,定義了菜單的一些屬性,注意“id=menu01”,前面提到過。
position、top、left、display四個CSS屬性即上一章講過的;
width、height、background-color分別為寬度、高度、背景色。
這里再一次出現(xiàn)onmouseover="menuShow(this)" onmouseout="menuHide(this)",
就是說當鼠標從菜單按鈕上移開,如果是移到了菜單上,菜單仍然顯示。
注意這里參數(shù)是this而不是menu01,this即對象本身,在這里就是指menu01,所以結果相同。
在這里筆者有意使用this,只是想告訴大家一個技巧,這在很多時候非常方便。
--></font>
<br> 菜單內(nèi)容
</div>
<script language=javascript>
function menuShow(menu) <font color="red">//定義顯示菜單的方法,參數(shù)menu即菜單的id。</font>
{
menu.style.display='block';
<font color="red"> //注意這里如何用javascript改變style對象的屬性來達到改變CSS屬性的目的。</font>
}
function menuHide(menu) <font color="red">//定義隱藏菜單的方法,參數(shù)menu即菜單的id。</font>
{
menu.style.display='none';
<font color="red">//同上</font>
}
</script>
</body>
</html>
------------------------------------------------------
這樣,一個簡單的菜單就實現(xiàn)了,只要你略有一些相關的基礎知識,反復體會一下我加的注釋,就應該可以理解了,是不是并不難?
這個菜單現(xiàn)在看上去還有點簡陋,下次我們將對這個菜單進行進一步的修飾。
樣式修飾這一章,我們就來討論如何美化它。
美化主要表現(xiàn)在鼠標放到菜單上后(即鼠標懸停)的效果,這里首先介紹幾個經(jīng)常用到的CSS屬性:
background-color:背景色,其值為一個顏色值,如“#FF0000”、“red”。
border:邊框樣式,一個形如“寬度 樣式 顏色”的字符串,如“1px solid red”,即1px的紅色實線邊框。
cursor:鼠標指針樣式,取值為表示鼠標指針樣式的字符串,如“hand”、“help”,即小手、幫助狀態(tài)。
以上只是簡單的介紹了幾個在此類菜單中非常常見的CSS屬性,這里也并未做很詳盡的解釋(畢竟這些并不是我們要講解的重點),欲了解更多可參閱相關資料。筆者在這里想說的是:掌握更多的CSS屬性會對你有所幫助。
前面說了,美化主要表現(xiàn)在鼠標放到菜單上后的效果,那么如何用JavaScript來控制樣式的變化呢?或者你會想到前面講過的style對象,的確,用style可以達到目的,但是,很多時候,需要改變很多個CSS屬性,用style就顯得有些麻煩。我們再來介紹一個新的屬性:className。
className屬性對應的就是CSS的class,也即所謂的偽類,比如在某個標記中設置class=myName,那么這時該元素的className屬性就是myName。
來看下面這個例子:
--------------------------------------------
<style type="text/css">
.style_normal { color: gray; }
.style_over { color: red; }
</style>
<span onmouseover="this.className='style_over'"
onmouseout="this.className='style_normal'">
鼠標移上來,通過className屬性改變這段文字的class,使文字顏色變成紅色;
移走,又恢復原來的顏色。</span>
----------------------------------------------
<font color="#4c408c">效果如下(把鼠標放到文字上):</font>
<!--#include virtual="http://jinyejixie.com/imagesnew/software/030804/0.html" -->
我們看到,在處理相對復雜的樣式變化的情況下,用className就方便得多了,至于樣式如何變化,就變成如何定義class的問題了。
講到這里,我想有一定CSS基礎的朋友應該已經(jīng)清楚如何來修飾這個菜單了,即便你對CSS了解的還不多,前面已經(jīng)介紹了幾個較常用的屬性。所以,這里就不再多講了,最后提供兩個筆者做好的例子,希望你能從中受到啟發(fā)(查看源文件即可看到相應的代碼,相應位置加了注釋,在此就不另行給出)。
<font color="#4c408c">1. 一個簡單的背景變化</font>
<!--#include virtual="http://www.yesky.com/imagesnew/software/030804/1.html" -->
<font color="#4c408c">2. 仿Office XP菜單效果</font>
<!--#include virtual="http://www.yesky.com/imagesnew/software/030804/2.html" -->
上面兩例都用了灰色,你當然可以改成你自己喜歡的顏色。這兩例也是比較常見的效果,這里提供給大家也算是拋磚引玉。相信開動你的腦筋、合理的運用掌握的技術,會做出更漂亮的效果!
定位問題通過前三篇文章的講解,現(xiàn)在我們已經(jīng)可以實現(xiàn)一個基本的菜單了。這一章,我們來討論一下定位的問題。
在前幾章講的例子中,定位都是相對于整個網(wǎng)頁的左上角。在有一些時候,我們可能需要它相對于網(wǎng)頁中某個元素定位,這樣做在某些時候是非常有必要的,比如不會出現(xiàn)那種因窗口大小的改變而致使菜單與網(wǎng)頁中的一些元素的相對位置發(fā)生變化。在第一章的最初,筆者所給的例子中就是這樣做的。
在那里我們很方便把就把這個菜單插入到了網(wǎng)頁中,而菜單不會相對菜單按鈕的位置發(fā)生變化。下面我們就看看如何來實現(xiàn)。
在第一章,我們講過position,當它取值absolute的時候,即絕對定位。既然是定位,就要有參照物。一般來講,這個定位的參照物是body(即整個網(wǎng)頁)的左上角,但如果其父級元素中有設置了position:absolute的元素,那么它的參照物就是該元素。知道了這樣一個特性,我們就可以很容易的來實現(xiàn)了。
另外,有一點在這里必須要著重說明一下,前面同時也講過,當position的值為relative時,就是相對定位,為什么不用它來實現(xiàn)呢?我們必須要正確理解這里所謂的相對定位:它是指相對于原來在HTML中的位置所發(fā)生的偏移,而它仍占據(jù)原來在HTML中所占據(jù)的位置。而我們現(xiàn)在的菜單需要“懸浮”在網(wǎng)頁元素之上,而這只有當position設為absolute時才可以做到。
通過上面的講述,我們應該可以大致的了解其實現(xiàn)的原理了。下面就看看剛才在上面看到的那個菜單的代碼(注意里面的注釋會幫你加深理解)。
------------------------------------------------------------
<style type=text/css>
td,div { font: normal 12px 宋體; }
a { color: #F8F8F8; text-decoration: none; }
a:hover { color: #F8F8F8; text-decoration: underline; }
</style>
<div style="background-color:#3366CC;width:68px;text-align:center;
padding:3px;border-bottom:1px solid #FFFFFF;z-index:1;"
onmouseover="myMenu.style.display='block'"
onmouseout="myMenu.style.display='none'">
<!--上面的DIV就是我們看到的按鈕部分,它并未涉及任何定位的部分,
不要與下面兩個混淆。-->
<div style="position:absolute;width:0px;height:0px;overflow:visible;">
<!--注意上面的DIV,設置了position:absolute,但是并沒有設置left/top,
所以這時它仍與一個普通的HTML元素一樣,出現(xiàn)在它應該出現(xiàn)的位置。-->
<div id=myMenu style="position:absolute;left:-10px;top:18px;
display:none;width:90px;background-color:#3366CC;
padding:5px;text-align:left;">
<!--它的定位是相對于前一個DIV而不是Body,
因為前一個DIV設置了position:absolute-->
<a href=#none>Link 1</a><br>
<a href=#none>Link 2</a><br>
<a href=#none>Link 3</a><br>
<a>...</a><br>
<a href=#none>Link N</a><br>
</div>
</div>
<a href=#none>菜單實例</a>
</div>
-------------------------------------------
請仔細理解上面的代碼,相信大家對用CSS進行絕對定位會有一個更深層次的認識!
這里說一句題外話:這種定位可以用Dreamweaver來實現(xiàn)(這對于對JS不是很熟的朋友來講的確很方便),而事實上這樣做生成的代碼的原理與上面講的相同的。把上面講的原理弄清楚了,使用起來會更靈活。
評語:網(wǎng)頁菜單在網(wǎng)站中是一個不錯的特效,可讓你的網(wǎng)站更具人性化。但這個效果多用在網(wǎng)站的導航欄目較多的情況下,作為一些小型的網(wǎng)站估計此特效也是無用武之地,不過也可運用網(wǎng)頁菜單的實現(xiàn)原理開發(fā)一些更實用的網(wǎng)頁互動功能。
本文來源于成都網(wǎng)站建設公司與成都網(wǎng)站設計制作公司-創(chuàng)新互聯(lián)成都公司!
新聞標題:網(wǎng)頁菜單,讓你的網(wǎng)站更具個性
文章來源:http://jinyejixie.com/news2/311352.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供做網(wǎng)站、定制網(wǎng)站、電子商務、靜態(tài)網(wǎng)站、網(wǎng)站內(nèi)鏈、網(wǎng)站策劃
廣告
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源:
創(chuàng)新互聯(lián)