• 软件测试技术
  • 软件测试博客
  • 软件测试视频
  • 开源软件测试技术
  • 软件测试论坛
  • 软件测试沙龙
  • 软件测试资料下载
  • 软件测试杂志
  • 软件测试人才招聘
    暂时没有公告

字号: | 推荐给好友 上一篇 | 下一篇

实现基于Ajax的无限级菜单

发布: 2008-1-29 16:18 | 作者: ycoe12 | 来源: www.blueidea.com | 查看: 30次 | 进入软件测试论坛讨论

领测软件测试网

 

首先建立一个数据表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方式。

文章来源于领测软件测试网 https://www.ltesting.net/

22/2<12

关于领测软件测试网 | 领测软件测试网合作伙伴 | 广告服务 | 投稿指南 | 联系我们 | 网站地图 | 友情链接
版权所有(C) 2003-2010 TestAge(领测软件测试网)|领测国际科技(北京)有限公司|软件测试工程师培训网 All Rights Reserved
北京市海淀区中关村南大街9号北京理工科技大厦1402室 京ICP备10010545号-5
技术支持和业务联系:info@testage.com.cn 电话:010-51297073

软件测试 | 领测国际ISTQBISTQB官网TMMiTMMi认证国际软件测试工程师认证领测软件测试网