| 网站首页 | 文章中心 | 电子书下载 | 矢量图库 | 视频教程 | 素材下载 | 程序代码下载 | JS代码 | 论坛 | 
常用软件类:
|杀毒安全 |联络聊天 |网络软件 |多媒体类 |系统工具 |图形图像 |系统工具 |应用软件 |行业软件
开发设计类:
|动画制作 |图像处理 |3D设计 |操作系统 |站长学院 |网络相关 |WEB设计 |数据库类 |程序开发
基于 Ajax 的无限级菜单
作者:佚名    文章来源:网络    点击数:    更新时间:2006-12-6
 




 
首先建立一个数据表menu 
mId  菜单主键 
name 菜单名称 
url  菜单链接 
father 低级菜单ID 
sub  是否最底层菜单(用于判断是否还可以继续展开) 
target 菜单链接目标(用ajax方式打开时作为显示id) 
pa   菜单参数(这项用于ajax方式打开菜单) 
制作一个菜单对象类 
class Menu{ 
private int mId; 
private String name; 
...//其它成员 
public getMid(){ 
return mId; 

public setMid(int mId){ 
this.mId = mId; 

....//其它成员的get set方法, 

另一个是操作类 
class MenuOpt(){ 
public Vector getMenus(int father){ 
Vector vector = new Vector(); 
//这里是取得父级菜单ID为father的全部菜单 
//并封装进Vector的一个对象中。。 
return vector; 


其次就是一般的jsp文件了。但要注意以前说过的,不要包含标签! 
menu.jsp: 
%@page contentType="text/html; charset=GB2312"%> 
%@taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> 
jsp:useBean id="menu" scope="page" class="ycoe.basic.MenuOpt"/> 
jsp:setProperty name="menu" property="father" value="${param.father}"/> 
div> 
c:forEach var="m" items="${menu.vector}" varStatus = "c"> 
c:choose> 
c:when test="${m.sub eq ’Y’}"> 
div onClick="showMenu(’${m.mid}’,’${m.url}’,’${m.target}’,’father=${m.mid}’)"> 
img src="pic/menu0.gif" id="img${m.mid}" alt="" style=" cursor:hand;"> 
a href="#" class="text1">${m.name} 
/div> 
div style="display:none;" id="tr${m.mid}"> 
div style="padding-left:12pt" id="${m.mid}"> 
/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} 
/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{ 
//如果里面有内容,直接显示 
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实现! 


最后是显示页面: 
%@ page contentType="text/html; charset=GB2312" %> 
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;} 
function ini(){ 
Bcandy("0","menu.jsp","id=0&father=0","menu.js"); 

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> 
div id="0" align="center"> 
可以看到,无论在哪个层面,都和传统的没什么分别,只有jsp部分除去文件头而已(其实不去掉也行的,呵呵),而且,还可以看到,一个页面,已经分成了好几部分。就像之前说的那样,积木式的(这是网上看到一篇关于.net框架的结构时作者提出的一种结构,觉得不错,被我应用到JSP来了)。 
在一些细节方面,我作了一些保留,请理解。但大致框架都是经过IE和FireFox测试。一些功能方面的扩展,自己想想了。 
原理:其实就是应用了页面递归!就和一般的递归方法一下,不过用在页面上而已 
div id="tr${m.id}"> 
循环,将从封装进vector的对象逐一显示出来 
for{ 
 if(如果是最上层菜单sub=N){ 
 div id="t${m.id}" onClick="ShowMenu(${m.father....})"> 
  显示菜单内容 
  
  
 div style="display:none" id="td${m.id....}"> 
 }else{ 
  div onClick="OpenMenu(${m.id})">显示菜单内容 
 } 

showMenu(father,id....)方法,将根据传入的father去服务器里取得数据后,再次调用这个页面。而这时,是将页面的内容显示在新的ID里面。这样,看起来就有和MSDN里的树菜单一样的效果了。 
优点:多级菜单多次获取,加快了反应速度,同时应用了ajax请求,让人感觉不到页面的闪烁,亲和力强。再者,可以JS里加入了代码,让用户不用每次点击都去获取服务器数据,而是先判断有没有内容,没有再取。。。同时,实现了菜单与页面的同步,在每打开一级菜单,都可以在相应的地方打开页面。同样,这个operMenu()也可以采用ajax方式。 
效果可以上 http://www.start.com/ 看看:

上一页  [1] [2] 


相关文章