利用AJAX+J2EE开发组织机构管理系统(1)

80酷酷网    80kuku.com

  ajax|j2ee|机构管理一、 概述

  AJAX是今年初才问世的新技术,是Asynchronous JavaScript and XML的缩写它是一组开发Web应用程序的技术,它使浏览器可以为用户提供更为自然的浏览体验每当需要更新时,客户端Web页面的修改是异步的和逐步增加的这样,AJAX在提交Web页面内容时大大提高了用户界面的速度在基于AJAX的应用程序中没有必要长时间等待整个页面的刷新页面中需要更新的那部分才进行更改,如果可能的话,更新是在本地完成的,并且是异步的

  J2ee是一种用来开发分布式系统的体系结构它主要是用Java类开发业务实体通过JSP来连接应用服务器

  本文开发一个组织机构管理小系统,通过这个实例来介绍如何用Ajax开发WEB应用程序本系统具有增加、修改、删除组织机构的功能同时给机构分配人员,能增加、修改、删除人员

  二、 界面设计

  树结构是大多软件系统中常采用的结构形式由于树型结构层次分明、上下级关系清楚、且展开收缩表达信息方便、界面也较美观,所以是大家热衷于用此结构组织机构管理是一般软件基本具有的组织机构是指公司的组织结构集团公司可包括分公子公司,公司下面又有科室员工归属于所在的公司系统运行后的界面如下:


  orgManager.htm是组织机构管理的主页面WEB应用程序界面设计是非常重要的如何布局、么样组织可直接体现一个人的设计水平
组织机构主要包括树结构、组织机构编辑、人员编辑等三大块,如何分成三块呢,然而一般树型结构的窗体常先二块,树型结构独占一块,另一块又分成上下二部分,上面是机构编码,下面是人员编码固可以把页面划分成如下图形式:

树结构区1 组织编码区2
人员管理区3

  显然我们是通过表来实现这是一个二行二列的表,且第一、二行的左边列合并单元格代码如下:

< TABLE border="1" width="100%" height="100%">
<TR>
<TD rowspan="2"><FONT face="宋体"></FONT></TD>
<TD></TD>
</TR>
<TR>
<TD></TD>
</TR>
</TABLE>

  我们在1区(单元格)上加上一个DIV,因为DIV可以动态地滚动,并且可以插入其它控件DIV的id为"divTree",且风格设置为溢出时自动滚动,宽与高都为100%,及满区域代码如下:

<div id="divTree" height:100%;background-color:#f5f5f5;border :1px solid Silver;overflow:auto;">
</div>

  我们在2区(单元格)上也加上一个DIV,在DIV里再插入一个表格表格上放下控件,这很简单,就不详细说了

  我们在3区(单元格)上加上一个DIV此DIV的id为" divContent ",且风格设置为竖直溢出时自动滚动,宽与高都为100%,及满区域,此DIV用来装载人员信息;在DIV里再插入一个表格, 此table的id为" tbList ",是用来输入、显示人员作息,同时在此表中插入一些如checkbox 、text、select等控件说明,表的第二列是用来放人员唯一编号的,不显示代码如下:

<div id="divContent" overflow-y:auto;" width="100%">
<table id="tbList" border="1" width="100%">
<tr seqNo="1"><td>
<table border="1" width="100%">
<tr>
<td width="5%"><input type="checkbox" value="on"></input> </td>
<td width="0%" <input type="text" size="20"></input></td>
<td width="40%"><input type="text" size="20"></input></td>
<td width="25%">
<select size="1" name="D1">
<option value="0">男</option>
<option selected="true" value="1">女</option>
</select>
</td>
</tr>
</table>
</td></tr>
</table>
</div>

 三、 前端页面的主要编码

  1. 树的实现

  在WEB上实现树结构,同样我们是通过Ajax来实现的树上可以显示自定义的图标,可以插入、删除、结点并且结点可任意移动这里我们不重点讲树的实现技术,我们已经封装好了,你只要按要求去改动就是了

  1) 键接树型文件

  在<head>与</head>之间键接我们的与树有关的文件, 代码如下:

<link rel="STYLESHEET" type="text/css" href="css/dhtmlXTree.css">
<script src="js/dhtmlXCommon.js"></script>
<script src="js/dhtmlXTree.js"></script>

  2) 装载方法

  在页面的文档打开时装载自定义方法, preLoadImages方法实现树控件的图标定义,doOnLoad实现树控件的图标定义代码如下:

<body >

  3) 编写方法

//doOnLoad实现装载并显示树设置树属性等
function doOnLoad(){
 OrgTree=new dhtmlXTreeObject(document.getElementById('divTree'),"100%","100%",0);
 //dhtmlXTreeObject是树对象,通过新建对象,指定树显示的DIV可定义树
 OrgTree.setImagePath("imgs/");//设置树的图片所在位置
 OrgTree.setDragHandler();//设置树结点拖动
 OrgTree.enableDragAndDrop(true) //设置树结点是否可拖动
 OrgTree.setDragHandler(myDragHandler); //设置树结点拖动时所执行的方法
 OrgTree.setOnClickHandler(mySelectHandler); //设置树单击时所执行的方法
 //OrgTree.setXMLAutoLoading("Org.jsp");//装载树结点数据数据来源如Org.jsp所返回的XML格式的字符串,数据是动态装载,且当展开时才装载
 OrgTree.loadXML("root.xml?0");//装载树结点数据数据来源root.xml文件,并且从xml文件的ID号为0处读取数据
 //OrgTree.loadXML("Org.jsp");//装载树结点数据数据来源如Org.jsp所返回的XML格式的字符串,并且是一次性全部装载数据
}
//preLoadImages方法实现树控件的图标定义
function preLoadImages(){
 var imSrcAr = new Array("line1.gif","line2.gif","line3.gif","line4.gif","minus2.gif","minus3.gif",
  "minus4.gif","plus2.gif","plus3.gif","plus4.gif","book.gif","books_open.gif","books_close.gif",
  "magazine_open.gif","magazine_close.gif","tombs.gif","tombs_mag.gif","book_titel.gif")
 var imAr = new Array(0);
 for(var i=0;i<imSrcAr.length;i++){
  imAr[imAr.length] = new Image();
  imAr[imAr.length-1].src = "imgs/"+imSrcAr[i]
 }
}

  2. 组织管理的实现

  组织可以增加、删除、编辑同时当选择树结点时应该把组织显示出来供编辑,查看为了实现这些功能,你只要按要求去改动就是了

  1) 全局变量的定义

  许多地方我们要用到一些公共变量,我们在<script>与</script>之间定义全局变量, 代码如下:

var OrgTree = null; //组织树Dom
var nextSeq = 0;//人员管理的顺序号(流水号)
var personDom;//人员Dom
var CurrNodeId;//当前结点Id

  2) 初始化

  当页面打开时我们要控件好那部分该显示,那部分要隐藏且对全局变量的赋值等,组织类型装载在页面的文档打开时装载自定义方法init(), init方法实现初始化

分享到
  • 微信分享
  • 新浪微博
  • QQ好友
  • QQ空间
点击: