html:原生javascript+css實(shí)現(xiàn)折疊層級(jí)菜單

前言

??今天來跟大家分享一下如何制作一個(gè)網(wǎng)頁中的左側(cè)菜單凑术,這個(gè)功能對(duì)于網(wǎng)頁來說也是常用的功能之一履澳,相當(dāng)于書簽一樣的功能。那么今天我們就來說一說如何實(shí)現(xiàn)一個(gè)折疊層級(jí)菜單的功能。
??那么折疊層級(jí)菜單長(zhǎng)什么樣签钩?下面我們來直觀的看一下硬霍,如下圖所示就是一個(gè)簡(jiǎn)單的層級(jí)菜單帜慢,共有四個(gè)菜單選項(xiàng),選擇哪一個(gè)選項(xiàng)就對(duì)應(yīng)地菜單下面相應(yīng)的內(nèi)容唯卖,如下截圖所示:

??那么對(duì)于這樣的層級(jí)菜單如何實(shí)現(xiàn)呢粱玲?用原生的javascript+css就可以來實(shí)現(xiàn),而且實(shí)現(xiàn)起來也不是很難拜轨,這里主要是通過用css對(duì)菜單定義兩種狀態(tài)抽减,一個(gè)用于折疊時(shí)顯示,另一個(gè)用于展開時(shí)顯示撩轰,而這兩個(gè)狀態(tài)的切換則使用JavaScript的單擊響應(yīng)函數(shù)來完成胯甩。在用JavaScript做狀態(tài)切換時(shí),我這里使用的是排他思想堪嫂,也就當(dāng)前點(diǎn)擊的菜單是一種狀態(tài)偎箫,其他的都是另一種狀態(tài),而實(shí)現(xiàn)排他思想的手段則是雙重for循環(huán)和自定義屬性皆串。下面來看一下具體如何實(shí)現(xiàn)吧淹办,具體代碼如下:

<html>
<head>
    <title>折疊層級(jí)菜單</title>
    <style type="text/css">
        body{margin: 0;text-align: center;}
        #mymenu {display: inline-block;margin:50px 100px 0 0;text-align: left;width: 23%;}
        #mymenu div{overflow: hidden;border-bottom: 10px solid #fff;}
        .menuspan{display: block;overflow: hidden;text-align: left;background-color: #d5a6bd;color: #ffffff;padding-left: 10px;height: 25px;line-height: 25px;}
        .menuspan:hover {color: grey;text-decoration: underline;}
        #mymenu a {display: block;padding-left: 30px;}
        #mymenu a:hover {color: grey;text-decoration: underline;}
        #mymenu div.collapsed{height: 25px;}
    </style>

    <script type="text/javascript">
        window.onload = function(){
            function hasclass(obj,clsname){
                var reg = new RegExp('\\b'+clsname+'\\b');
                return reg.test(obj.className);
            }

            function addclass(obj,clsname){
                if(!hasclass(obj,clsname)){
                    obj.className += ' ' + clsname;
                }
            }

            function removeclass(obj,clsname){
                var reg = new RegExp('\\b'+clsname+'\\b');
                obj.className = obj.className.replace(reg,'');
            }

            function toggleclass(obj,clsname){
                var reg = new RegExp('\\b'+clsname+'\\b');
                if(hasclass(obj,clsname)){
                    removeclass(obj,clsname);
                }else{
                    addclass(obj,clsname);
                }
            }

            function getstyle(obj, styname) {
                if(window.getComputedStyle){
                    return getComputedStyle(obj,null)[styname];
                }else{
                    return obj.currentStyle[styname];
                }
            }

            var menuspan = document.querySelectorAll('.menuspan');

            for(var i=0;i < menuspan.length;i++){
                menuspan[i].index = i;
                menuspan[i].onclick = function(){
                    var parentdiv = this.parentNode;
                    toggleclass(parentdiv,'collapsed'); 
                    for(var j=0;j< menuspan.length;j++){
                        var otherdiv = menuspan[j].parentNode;
                        if(this.index != menuspan[j].index){
                            addclass(otherdiv,'collapsed');
                        }
                    }   
                }
            }
        }
    </script>
</head>
<body>
    <div id='mymenu'>
        <div class="collapsed">
            <span class="menuspan">在線工具</span>
            <a href="#">圖像優(yōu)化</a>
            <a href="#">收藏夾</a>
            <a href="#">郵件</a>
            <a href="#">密碼</a>
            <a href="#">梯度圖像</a>
        </div>
        <div class="collapsed">
            <span class="menuspan">支持我們</span>
            <a href="#">推薦我們</a>
            <a href="#">聯(lián)系我們</a>
            <a href="#">網(wǎng)絡(luò)資源</a>
        </div>
        <div class="collapsed">
            <span class="menuspan">合作伙伴</span>
            <a href="#">javascript工具包</a>
            <a href="#">css浮動(dòng)</a>
            <a href="#">condingforums</a>
            <a href="#">css例子</a>
        </div>
        <div class="collapsed">
            <span class="menuspan">測(cè)試電流</span>
            <a href="#">高壓電1</a>
            <a href="#">高壓電2</a>
            <a href="#">高壓電3</a>
        </div>
    </div>
</body>
</html>

??上面的代碼實(shí)現(xiàn)了折疊層級(jí)菜單的功能,共有四個(gè)主菜單恶复,每個(gè)菜單下又隱藏若干子菜單怜森,當(dāng)單擊某個(gè)菜單時(shí)會(huì)打開該菜單下面的子菜單,再次單擊該菜單會(huì)隱藏下面的子菜單谤牡,還有就是菜單之間是互斥的副硅,即打開一個(gè)菜單會(huì)關(guān)閉其他的菜單。最終效果如下所示:

最后

??對(duì)于折疊層級(jí)菜單翅萤,網(wǎng)上的很多帖子都是使用 jQuery庫(kù)來實(shí)現(xiàn)恐疲,而本貼使用的是原生JavaScript+css結(jié)合雙重for手段來具體實(shí)現(xiàn)。emm套么,今天就分享到這里了培己。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
禁止轉(zhuǎn)載,如需轉(zhuǎn)載請(qǐng)通過簡(jiǎn)信或評(píng)論聯(lián)系作者胚泌。
  • 序言:七十年代末省咨,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子玷室,更是在濱河造成了極大的恐慌零蓉,老刑警劉巖笤受,帶你破解...
    沈念sama閱讀 219,270評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異敌蜂,居然都是意外死亡感论,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,489評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門紊册,熙熙樓的掌柜王于貴愁眉苦臉地迎上來比肄,“玉大人,你說我怎么就攤上這事囊陡》技ǎ” “怎么了?”我有些...
    開封第一講書人閱讀 165,630評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵撞反,是天一觀的道長(zhǎng)妥色。 經(jīng)常有香客問我,道長(zhǎng)遏片,這世上最難降的妖魔是什么嘹害? 我笑而不...
    開封第一講書人閱讀 58,906評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮吮便,結(jié)果婚禮上笔呀,老公的妹妹穿的比我還像新娘。我一直安慰自己髓需,他們只是感情好许师,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,928評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著僚匆,像睡著了一般微渠。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上咧擂,一...
    開封第一講書人閱讀 51,718評(píng)論 1 305
  • 那天逞盆,我揣著相機(jī)與錄音,去河邊找鬼松申。 笑死云芦,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的攻臀。 我是一名探鬼主播焕数,決...
    沈念sama閱讀 40,442評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼纱昧,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼刨啸!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起识脆,我...
    開封第一講書人閱讀 39,345評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤设联,失蹤者是張志新(化名)和其女友劉穎善已,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體离例,經(jīng)...
    沈念sama閱讀 45,802評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡换团,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,984評(píng)論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了宫蛆。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片艘包。...
    茶點(diǎn)故事閱讀 40,117評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖耀盗,靈堂內(nèi)的尸體忽然破棺而出想虎,到底是詐尸還是另有隱情,我是刑警寧澤叛拷,帶...
    沈念sama閱讀 35,810評(píng)論 5 346
  • 正文 年R本政府宣布舌厨,位于F島的核電站,受9級(jí)特大地震影響忿薇,放射性物質(zhì)發(fā)生泄漏裙椭。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,462評(píng)論 3 331
  • 文/蒙蒙 一署浩、第九天 我趴在偏房一處隱蔽的房頂上張望揉燃。 院中可真熱鬧,春花似錦筋栋、人聲如沸你雌。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,011評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽婿崭。三九已至,卻和暖如春肴颊,著一層夾襖步出監(jiān)牢的瞬間氓栈,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,139評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工婿着, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留授瘦,地道東北人韧骗。 一個(gè)月前我還...
    沈念sama閱讀 48,377評(píng)論 3 373
  • 正文 我出身青樓驰吓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親薇缅。 傳聞我的和親對(duì)象是個(gè)殘疾皇子丘侠,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,060評(píng)論 2 355