js左側(cè)多級(jí)菜單動(dòng)態(tài)的解決方案
更新時(shí)間:2010年02月01日 00:30:25 作者:
實(shí)現(xiàn)的效果很簡(jiǎn)單,就是點(diǎn)一下顯示,再點(diǎn)一下就隱藏,只不過是多了幾級(jí)的問題。好,現(xiàn)在來說說我的設(shè)計(jì)思路,首先從第一級(jí)別開始,添加如下代碼
復(fù)制代碼 代碼如下:
<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>
這就出現(xiàn)兩次類別了,點(diǎn)父級(jí)顯示(隱藏)子級(jí)菜單,JS代碼也就一句話:
復(fù)制代碼 代碼如下:
function news_pro(o)
{
var obj=document.getElementById(o)
obj.style.display==""? obj.style.display="none": obj.style.display="";
}
是不是有點(diǎn)太簡(jiǎn)單了,沒錯(cuò),就是這么簡(jiǎn)單,不過還沒完,我們繼續(xù)往下看;接著添加三級(jí)和四級(jí)子菜單:
復(fù)制代碼 代碼如下:
<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!當(dāng)你點(diǎn)其中的一級(jí)時(shí),頁面發(fā)生跳轉(zhuǎn),這是我們想要的,但是左邊的菜單卻又變成了原來的樣子,并沒有保存我剛才點(diǎn)擊的狀態(tài),那該怎么辦呢?因?yàn)橥率且玫紸SP里去,好像沒有視圖狀態(tài)這個(gè)東東,那用session保存嗎?好像能行得通,但是如果你點(diǎn)擊快一點(diǎn),就發(fā)現(xiàn)菜單有時(shí)候點(diǎn)幾次都會(huì)不同,根本反應(yīng)不過來或是session丟失了,最后不巧我發(fā)現(xiàn)我的命名很有意思,一級(jí)是1,二級(jí)是1.1三級(jí)是1.1.1,四級(jí)是1.1.1.1,想到什么?想到了數(shù)據(jù)庫設(shè)計(jì)多級(jí)類別的查詢吧?。亢孟馾iscuz里面的類別就是這么設(shè)計(jì)的。它查詢也很快,那我也給它來個(gè)快速的,靈機(jī)一動(dòng),就so happy了。
代碼如下,采用url傳值的方式:
復(fù)制代碼 代碼如下:
<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>
我相信這個(gè)代碼不管理asp或是asp.net都區(qū)別不大,其實(shí)用純js也可以做到,不過既然是用在asp里的,干嘛要多寫js呢?好了,功能實(shí)現(xiàn)了。大家都OK了,如果你有不同的方法,歡迎貼出來大家一起分享。從學(xué)習(xí)中進(jìn)步。。。
您可能感興趣的文章:
- vue.js 左側(cè)二級(jí)菜單顯示與隱藏切換的實(shí)例代碼
- javascript仿京東導(dǎo)航左側(cè)分類導(dǎo)航下拉菜單效果
- JS實(shí)現(xiàn)新浪博客左側(cè)的Blog管理菜單效果代碼
- JS實(shí)現(xiàn)的左側(cè)豎向滑動(dòng)菜單效果代碼
- JS+CSS實(shí)現(xiàn)經(jīng)典的左側(cè)豎向滑動(dòng)菜單效果
- js實(shí)現(xiàn)的后臺(tái)左側(cè)管理菜單代碼
- 原生JS實(shí)現(xiàn)仿淘寶網(wǎng)左側(cè)商品分類菜單效果代碼
- js實(shí)現(xiàn)的四級(jí)左側(cè)網(wǎng)站分類菜單實(shí)例
- js左側(cè)三級(jí)菜單導(dǎo)航實(shí)例代碼
- JavaScript實(shí)現(xiàn)左側(cè)菜單效果
相關(guān)文章
使用JSX實(shí)現(xiàn)Carousel輪播組件的方法(前端組件化)
做這個(gè)輪播圖的組件,我們先從一個(gè)最簡(jiǎn)單的 DOM 操作入手。使用 DOM 操作把整個(gè)輪播圖的功能先實(shí)現(xiàn)出來,然后在一步一步去考慮怎么把它設(shè)計(jì)成一個(gè)組件系統(tǒng)2021-04-04小程序如何獲取多個(gè)formId實(shí)現(xiàn)詳解
這篇文章主要介紹了小程序如何獲取多個(gè)formId實(shí)現(xiàn)詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-09-09基于JavaScript實(shí)現(xiàn)百葉窗動(dòng)畫效果不只單純flas可以實(shí)現(xiàn)
看到這種百葉窗效果的動(dòng)畫,以為是用flash做的,下面通過本文給大家介紹基于JavaScript實(shí)現(xiàn)百葉窗動(dòng)畫效果,需要的朋友參考下吧2016-02-02小程序云開發(fā)實(shí)現(xiàn)數(shù)據(jù)庫異步操作同步化
這篇文章主要為大家詳細(xì)介紹了小程序云開發(fā)實(shí)現(xiàn)數(shù)據(jù)庫異步操作同步化,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-05-05測(cè)量JavaScript函數(shù)的性能各種方式對(duì)比
這篇文章主要介紹了測(cè)量JavaScript函數(shù)的性能各種方式對(duì)比,對(duì)性能感興趣的同學(xué),可以多實(shí)驗(yàn)一下2021-04-04JavaScript基礎(chǔ)篇之變量作用域、傳值、傳址的簡(jiǎn)單介紹與實(shí)例
這篇文章介紹了變量的作用域,傳值,傳址的一些簡(jiǎn)單使用,有需要的朋友可以參考一下2013-06-06