</div>
</c:when>
<c:otherwise>
<div onclick="openMenu(’${m.url}’,’${m.target}’,’${m.pa}’);">
<img src="pic/menu1.gif" id="img${m.mid}" alt="">
<a href="#" class="text1">${m.name}</a>
</div>
</c:otherwise>
</c:choose>
</c:forEach>
</div>
menu.js:
//operMenu(打开下拉菜单的ID,打开的地址,链接打开的目标,参数)。
//这是用在menu.jsp的方法
function showMenu(id,url,target,param){
var trObj = document.getElementById("tr" id);
var tdObj = document.getElementById(id);
//try{
if(document.getElementById("tr" id).style.display == "none"){
//显示菜单
if(tdObj.innerHTML == null || tdObj.innerHTML == ""){
//提取数据
document.getElementById("tr" id).style.display = "";
document.getElementById("img" id).src = "pic/menu2.gif"
Bcandy(id,"page/menu.jsp",param,"");
openMenu(url,target,param);
}else{
//如果里面有内容,直接显示
字串4
document.getElementById("tr" id).style.display = "";
document.getElementById("img" id).src = "pic/menu2.gif"
openMenu(url,target,param);
}
//Bcandy(target,url,param,"");//打开菜单链接
}else{
//隐藏菜单
document.getElementById("tr" id).style.display = "none";
document.getElementById("img" id).src = "pic/menu0.gif"
}
//}catch(e){}
}
//打开菜单
function openMenu(url,target,param){
//这里不用我写了吧。有好几种实现方法,建议使用ajax实现!
} 字串4
最后是显示页面:
字串3
字串4
<%@ page contentType="text/html; charset=GB2312" %> 字串5
<meta http-equiv=Content-Type content="text/html; charset=gb2312">
<style>
.text1:hover { border: 1px #999999 solid; background-color: #CCCCCC; height: 12px;}
.text1{border: 1px #FFFFFF solid; height: 12px;}
</style>
<script type="" src="js/Function.js"></script>
function ini(){
Bcandy("0","menu.jsp","id=0&father=0","menu.js");
}
</script>
<body onload="ini();">
<div id="load" style="z-index:1; color:#FF0000; visibility:hidden; filter: Alpha(opacity=85); background-color:#FFFFFF; left: 48%; top: 48%;BORDER-RIGHT: #000000 1px solid; PADDING-RIGHT: 12px; BORDER-TOP: #000000 1px solid; PADDING-LEFT: 12px;PADDING-BOTTOM: 12px; BORDER-LEFT: #000000 1px solid; LINE-HEIGHT: 22px; PADDING-TOP: 12px; BORDER-BOTTOM: #000000 1px solid; POSITION: absolute;">
<img src='pic/loop.gif' alt=""><br>
数据处理中,请稍候...
<br>
</div>
<div id="0" align="center">
</div>
</body>
</html> 字串7
字串4
可以看到,无论在哪个层面,都和传统的没什么分别,只有jsp部分除去文件头而已(其实不去掉也行的,呵呵),而且,还可以看到,一个页面,已经分成了好几部分。就像之前说的那样,积木式的(这是网上看到一篇关于.net框架的结构时作者提出的一种结构,觉得不错,被我应用到JSP来了)。
在一些细节方面,我作了一些保留,请理解。但大致框架都是经过IE和FireFox测试。一些功能方面的扩展,自己想想了。 字串6
原理:其实就是应用了页面递归!就和一般的递归方法一下,不过用在页面上而已
字串6
<div id="tr${m.id}">
循环,将从封装进vector的对象逐一显示出来
for{
if(如果是最上层菜单sub=N){
<div id="t${m.id}" onClick="ShowMenu(${m.father....})">
显示菜单内容
</div>
<!--这里不显示内容,仅作为下一次的容器-->
<div style="display:none" id="td${m.id....}"></div>
}else{
<div onClick="OpenMenu(${m.id})">显示菜单内容</div>
}
}
</div> 字串1
showMenu(father,id....)方法,将根据传入的father去服务器里取得数据后,再次调用这个页面。而这时,是将页面的内容显示在新的ID里面。这样,看起来就有和MSDN里的树菜单一样的效果了。 字串3
优点:多级菜单多次获取,加快了反应速度,同时应用了ajax请求,让人感觉不到页面的闪烁,亲和力强。再者,可以JS里加入了代码,让用户不用每次点击都去获取服务器数据,而是先判断有没有内容,没有再取。。。同时,实现了菜单与页面的同步,在每打开一级菜单,都可以在相应的地方打开页面。同样,这个operMenu()也可以采用ajax方式。
字串8
效果可以上 http://www.start.com/ 看看: 字串3


