一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

js 全兼容可高亮二級緩沖折疊菜單

在后臺或OA系統(tǒng)中最常用到的布局往往是一個全屏布局,一般都是上中下三行兩列布局,頁頭、頁腳、左側(cè)菜單加一個右側(cè)ifame框架頁。所以那種帶折疊的二級菜單是會經(jīng)常使用到的,本例便是實現(xiàn)這樣一種比較通用的全兼容可高亮二級緩沖折疊菜單。

特點:

全兼容,瀏覽器測試:IE5.5、IE6、IE7、IE8、FF3.0、谷歌、Safari 4.0、Opera9.0。
Html結(jié)構(gòu)優(yōu)雅簡潔,無多余標簽,利于程序循環(huán)輸出。
樣式與結(jié)構(gòu)分離,你可以在樣式表中修改不同的風格。
當前選中項高亮狀態(tài),一級菜單和二級菜單都可以高亮顯示。
折疊層優(yōu)雅緩沖動畫。
最適用于后臺和一些OA系統(tǒng)界面。

缺點:

不支持防刷新,這個功能在后臺應(yīng)用系統(tǒng)中應(yīng)該用途不大,沒有加入這個功能。
在IE6中緩沖效果沒有出來,對于IE6,就弱化一下效果。
還是先看看效果截圖:

簡單說一下制作這樣的菜單的一些簡單的思路和會遇到的問題。

一般制作一個效果,我的制作流程一般是先畫出HTML結(jié)構(gòu)層內(nèi)容,再寫樣式,之后是搞一些錦上添花的效果,如JS特效等等。不知各位大牛們是怎樣一個流程模式。

結(jié)構(gòu)層:

結(jié)構(gòu)層的構(gòu)思一般是建立在一個感性認識上的,一般是有一個效果圖,根據(jù)這個效果圖構(gòu)建最簡潔的HTML結(jié)構(gòu)。如上圖所示,映入眼簾的第一印象,首先是想到用一個UL的無序列表,但是…這是一個二級嵌套的列表,這是我們首先需要考慮的問題。

因此結(jié)構(gòu)應(yīng)該是下面這樣子:

復(fù)制代碼 代碼如下:
<li><a href="#none">一級菜單項</a>
<ul>
<li><a href="#none">二級菜單項</a></li>
</ul>
</li>

在有二級菜單時是一個嵌套的UL結(jié)構(gòu),無二級菜單時則是如下:
復(fù)制代碼 代碼如下:
<ul class="menu">
<li><a href="#none">一級菜單項</a></li>
</ul>

當然,你也可以采用dl-dt-dd有序列表的方式來創(chuàng)建這種嵌套的結(jié)構(gòu),視你的實際情況而定。

有了最原始的結(jié)構(gòu)層,你就需要添加一些必要的鉤子,用于CSS和JS控制樣式和效果,我一直反對那種添加很多類名的寫法,這會增加頁面的體積,所以最精簡的作法是應(yīng)用一兩個必要的類名給父容器即可,然后在樣式表中用子(群)選擇符設(shè)置各種個性的設(shè)置。在上面的結(jié)構(gòu),你會想到用幾個類名來定義所有的樣式呢?

我的做法是只用三個類名即可以控制全部的樣式顯示了。一個是最頂級UL,定義為class=”menu”,一個是二級菜單的容器,也就是嵌套的UL定義一個class=”level2”,最后是一級菜單項li定義一個class=”level1”,有了這三個鉤子,你就可以操縱整個結(jié)構(gòu)的樣式了。

表現(xiàn)層:

樣式表的設(shè)置都很簡單,唯一要注意的是,為了便于JS控制二級菜單的顯隱和記錄當前選中項的高亮狀態(tài),所以我不用hover偽類來實現(xiàn)鼠標的滑入滑出效果,而采用JS來模擬它。用JS控制樣式的關(guān)鍵代碼如下:

一級菜單樣式
復(fù)制代碼 代碼如下:
/*一級菜單三態(tài)樣式,供JS調(diào)用*/
.menu li.level1 a{display:block;line-height:31px;height:31px;padding-left:50px; font-size:12px;color:#fff;background:url(../images/menubg.gif) no-repeat left top;}
.menu li.level1 a.hove{background-position:left -31px;}
.menu li.level1 a.cur{background-position:left -62px;}

二級菜單樣式
復(fù)制代碼 代碼如下:
/*二級菜單三態(tài)樣式,供JS調(diào)用*/
.menu li.level1 a{display:block;line-height:31px;height:31px;padding-left:50px; font-size:12px;color:#fff;background:url(../images/menubg.gif) no-repeat left top;}
.menu li.level1 a.hove{background-position:left -31px;}
.menu li.level1 a.cur{background-position:left -62px;}

行為層:

因為前面已經(jīng)提到,我們在樣式表并沒有定義菜單的三態(tài)效果,所以我們需要給每個菜單項綁定onmouseover、onmouseout和onclick事件模擬出這種效果來。在結(jié)構(gòu)層中我們并沒有定義這個總?cè)萜鞯腎D,而只定義了一個class類名,所以在JS添加了一個擴展的getElementsByClassName()方法(感謝好友司徒正美),根據(jù)類名來獲得這個對象。用循環(huán)閉包來綁定這三個事件。

詳細代碼就不一一解說了,Demo中注釋得非常清楚,請下載到本機瀏覽。

有什么問題請在本博客中跟貼討論,祝你用得開心!
在線演示地址 http://demo.jb51.NET/js/caidan_js/demo.html
打包下載地址 http://www.jb51.NET/jiaoben/27308.html

JavaScript技術(shù)js 全兼容可高亮二級緩沖折疊菜單,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 色多多视频在线观看 | 海外毛片 | 色哟哟在线观看视频 | 91国语精品自产拍在线观看性色 | 久久香蕉国产精品一区二区三 | 婷婷六月天在线 | 美女黄区 | 国产亚洲精品午夜高清影院 | 伊人小婷婷色香综合缴缴情 | a级精品国产片在线观看 | 色婷婷六月丁香在线观看 | 播放久久国产乱子伦精品 | 久久99国产亚洲高清观看首页 | 女人十八黄毛片 | 日本一区二区成人教育 | 亚洲国产精品线播放 | 涩五月婷婷| 精品麻豆国语国拍视频在线 | 男人把女人c爽的免费视频 男人操女人免费视频 | riav久久中文一区二区 | 国产一区二区三区免费观看 | 亚洲三级自拍 | 日韩 欧美 国产 亚洲 中文 | 成人在线免费视频 | 欧美高清在线观看视频 | 国产精品区网红主播在线观看 | 91久久国产成人免费观看资源 | 女女同性一区二区三区四区 | 久久99精品久久久久子伦 | 九九热亚洲精品综合视频 | 国产精品播放 | 美女视频黄免费 | 国产麻豆91| 中文字幕精品视频 | 成年人视频免费在线播放 | 99久久久精品免费观看国产 | 精品国产成人 | 精品女同一区二区三区免费站 | 国产情侣第一页 | 91福利免费| 欧美三级黄|