程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> ASP編程 >> 關於ASP編程 >> ASP中js左側多級菜單動態的解決方案

ASP中js左側多級菜單動態的解決方案

編輯:關於ASP編程

     昨晚想搞一個js菜單,搞了一個晚上都沒弄出來。後來百度了下,有點狂汗~~~

    實現的效果很簡單,就是點一下顯示,再點一下就隱藏,只不過是多了幾級的問題。好,現在來說說我的設計思路,首先從第一級別開始,添加如下代碼:

    <div><a onclick="news_pro('1.1')">1</a></div> 
    <div id="1.1" >
    <div> <a onclick="news_pro('1.1.1')">1.1</a></div>
    </div>

    這就出現兩次類別了,點父級顯示(隱藏)子級菜單,JS代碼也就一句話:

    function news_pro(o)
    {
    var obj=document.getElementById(o)
    obj.style.display==""? obj.style.display="none": obj.style.display=""; 
    }

    是不是有點太簡單了,沒錯,就是這麼簡單,不過還沒完,我們繼續往下看;接著添加三級和四級子菜單:

    <div><a onclick="news_pro('1.1')">1</a></div>
    <div id="1.1">
    <div> <a onclick="news_pro('1.1.1')">1.1</a></div>
    <div id="1.1.1" >
    <div>  <A onclick="news_pro('1.1.1.1')">1.1.1</a></div>
    <div id="1.1.1.1">
    <div>   1.1.1.1</div>
    <div>   1.1.1.2</div>
    </div>
    <div>  1.1.2</div>
    </div>
    <div> 1.2</div>
    <div> 1.3</div>
    </div> 
    js代碼還是只有那一行,so easy吧,可是真的就這樣完了嗎?答案是NONONO!當你點其中的一級時,頁面發生跳轉,這是我們想要的,但是左邊的菜單卻又變成了原來的樣子,並沒有保存我剛才點擊的狀態,那該怎麼辦呢?因為同事是要用到ASP裡去,好像沒有視圖狀態這個東東,那用session保存嗎?好像能行得通,但是如果你點擊快一點,就發現菜單有時候點幾次都會不同,根本反應不過來或是session丟失了,最後不巧我發現我的命名很有意思,一級是1,二級是1.1三級是1.1.1,四級是1.1.1.1,想到什麼?想到了數據庫設計多級類別的查詢吧!?好像discuz裡面的類別就是這麼設計的。它查詢也很快,那我也給它來個快速的,靈機一動,就so happy了。

    代碼如下,采用url傳值的方式:

    <div><a onclick="news_pro('1.1')" href="?id=1.1">1</a></div>
    <div id="1.1" <%If InStr(request.querystring("id"),"1.1")=0 Then response.write style='display:none;'%>>
    <div> <a onclick="news_pro('1.1.1')" href="?id=1.1.1">1.1</a></div>
    <div id="1.1.1" style="display:none;" <%If InStr(request.querystring("id"),"1.1.1")=0 Then response.write style='display:none;'%>>
    <div>  <A onclick="news_pro('1.1.1.1')" href="?id=1.1.1.1">1.1.1</a></div>
    <div id="1.1.1.1" <%If InStr(request.querystring("id"),"1.1.1.1")=0 Then response.write style='display:none;'%>>
    <div>   1.1.1.1</div>
    <div>   1.1.1.2</div>
    </div>
    <div>  1.1.2</div>
    </div>
    <div> 1.2</div>
    <div> 1.3</div>
    </div>
    <div><a >2</a></div>
    <div><a >3</a></div>

    我相信這個代碼不管理asp或是asp.net都區別不大,其實用純js也可以做到,不過既然是用在asp裡的,干嘛要多寫js呢?好了,功能實現了。大家都OK了,如果你有不同的方法,歡迎貼出來大家一起分享。從學習中進步。。。

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved