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

心甘情愿_为你

心甘情愿_为你

2016-02-19 15:04

想要天天向上,就要懂得享受学习。图老师为大家推荐利用AJAX+J2EE开发组织机构管理系统,精彩的内容需要你们用心的阅读。还在等什么快点来看看吧!
一、 概述

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

(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)

  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" style="width:100%; 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" style="height:100%; 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%" style="display:none"> <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

documentElement;
 oNodeList = root.childNodes;
 txtType.options.length =oNodeList.length;
 for (var i=0; i<oNodeList.length; i++)
 {
  Item = oNodeList.item(i);
  var OrgTypeId=Item.childNodes(0).text;
  var OrgTypeName=Item.childNodes(1).text;
  txtType.options[i].value=OrgTypeId;
  txtType.options[i].text=OrgTypeName;
  // txtType.options[0].
 }
}

 

  3) 编写树拖动及选择结点的方法

// myDragHandler实现树结点拖动时重新指定父子关系。
function myDragHandler(idFrom,idTo){
 var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
 xmlhttp.open("POST","Org.jsp?mode=moveOrg&orgId=" + idFrom + "&newparentOrgId=" + idTo, false);
 xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
 xmlhttp.send();
 retXml=xmlhttp.OrgponseText;

 return true;
}
// mySelectHandler实现选择树结点对系统的控制,同时显示组织信息及该组织下的人员。
function mySelectHandler(id){
 tbOrg.style.display="block";
 divOrgMemo.style.display="none";
 divOrgInfo.style.display="none";

 if(id==1)
 {
  divOrgMemo.style.display="block";
  div1.style.display="none";
  div2.style.display="none";
  div3.style.display="none";
  divContent.style.display="none";
  div5.style.display="none";
 }
 else
 {
  divOrgInfo.style.display="block";
  div1.style.display="block";
  div2.style.display="block";
  div3.style.display="block";
  divContent.style.display="block";
  div5.style.display="block";
 }
 CurrNodeId=id;
 //装载组织信息并显示在编码和名称的文本控件上。
 loadOrg(id);
 //装载某组织下人员信息
 var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
 xmlhttp.open("POST","Org.jsp?mode=GetPerson&orgId=" + id, false);
 xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
 xmlhttp.send();

 retXml=xmlhttp.responseText;
 personDom.loadXML (retXml);
 //给人员信息的每行加上序号
 for(var i=0; i<personDom.documentElement.childNodes.length; i++){
  personDom.documentElement.childNodes[i].setAttribute("seqNo", nextSeq);
  nextSeq++;
 }
 //人员信息显示在divContent上面
 divContent.innerHTML = personDom.transformNode(stylesheet);
};
//装载组织信息并显示在编码和名称的文本控件上。
function loadOrg(OrgId){
 if(OrgId == null){
  OrgId = OrgTree.getSelectedItemId();
 }
 if(OrgId == ""){
  tbOrg.style.display = "none";
  return;
 }
 var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
 xmlhttp.open("POST","Org.jsp?mode=loadOrg&OrgId=" + OrgId, false);
 xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
 xmlhttp.send();
 retXml=xmlhttp.responseText;
 var OrgDoc = new ActiveXObject('Microsoft.XMLDOM');
 OrgDoc.async = false;
 OrgDoc.loadXML(retXml);
 if(OrgId != 1){
  txtCode.value = OrgDoc.selectSingleNode("//OrgCode").text;
  txtName.value = OrgDoc.selectSingleNode("//OrgName").text;
 }
 tbO

rsonCode", "");
 peorsonNode.appendChild(personCode);
 var PersonName= personDom.createNode("1", "personName", "");
 peorsonNode.appendChild(PersonName);
 var Sex= personDom.createNode("1", "sex", "");
 peorsonNode.appendChild(Sex);
 var tr = tbList.insertRow(tbList.rows.length);
 tr.setAttribute("seqNo", seqNo);
 var td = tr.insertCell(0);
 td.innerHTML = peorsonNode.transformNode(stylesheet);
}

 

  2) 删除人员

  人员删除同样是调用Org.jsp 文件中的deletePerson方法来实现,该方法传递所删除的人员ID。如何确定人员ID是通过读取隐藏的ID,并扫描整个表,看那些被选中。这里我们要注意是提供多项选择的。

function deletePerson(){
 for(var i=0; i<tbList.rows.length; i++){
  var row=tbList.rows[i].cells[0].children[0].rows[0];
  if(row.cells[0].children[0].checked)
  {
   var personId=row.cells[1].children[0].value;
   if(personId>0)
   {
    var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
    xmlhttp.open("POST","Org.jsp?mode=deletePerson&personId=" + personId, false);
    xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
    xmlhttp.send();
   }
   tbList.deleteRow(i);
   i--;
  }
 }
}

  3) 编辑人员

  人员修改我们要判定哪些行被修改了。刚增加但没保存的行应该是新增而不是修改的。

function save(){
 if( modifyOrg()=="N")
 {
  return;
 }
 for(var i=0; i<tbList.rows.length; i++)
 {
  var row=tbList.rows[i].cells[0].children[0].rows[0];
  var personId=row.cells[1].children[0].value;
  var seqNo = tbList.rows[i].getAttribute("seqNo");
  var staffNode = personDom.selectSingleNode("//peorsone[@seqNo='" + seqNo + "']");
  var personCode=row.cells[2].children[0].value;
  var personName=row.cells[3].children[0].value;
  var sex=row.cells[4].children[0].value; //alert(staffN;ode );
  if(staffNode.getAttribute("isNew") == "Y")
  {
   createPerson(CurrNodeId,personCode,personName,sex);
  }
  else
  {
   var strXML = "<?xml version='1.0' encoding='gb2312'?>" +
    "<data>" +
    "<personCode><![CDATA[" + personCode+ "]]></personCode>" +
    "<personName><![CDATA[" + personName + "]]></personName>" +
    "<sex><![CDATA[" + sex+ "]]></sex>" +
    "<personId><![CDATA[" + personId+ "]]></personId>" +
    "</data>";
   //alert(strXML );
   var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
   xmlhttp.open("POST","Org.jsp?mode=modifyPerson", false);
   xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
   xmlhttp.send(strXML );
  }
 }
}

  四、 XML与XSL文件设计

  XML是种可扩展的标记语言,它具有开放的、可扩展的、可自描述的语言结构,它已经成为网上数据和文档传输的标准。XSLT的目的是将信息内容与 Web 显示分离,HTML 通过按抽象概念(如段落、重点和编号列表)定义显示来实现设备独立性。XSLT用来具体显示控件,设置控件风格。

  Ajax主要使用XML和XSLT进行数据交换与处理。

  1. 树信息的XML文件(见root.xml文件)

(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)

  XML是标记语言,元素必须成对出现。树结构中以tree为根结点,以item为结点体,属性text指出结点所显示的文本,id指

sql.*" %>
<%@ page import="javax.naming.*" %>
<%@ page import="javax.sql.*" %>
<%@ page import="tool.*" %>
<%@ page import="orgNew.*" %>
<%@ page import="org.w3c.dom.*" %>
//上面主要是引用一些java类
<%
try{
 //request.setCharacterEncoding("GBK");
 Document doc = XmlTool.createDocumentFromRequest(request);
 //建立web面文档请求的文档对象
 Connection conn = ConnTool.getConnectionFromPool();
 //获取请求的方法名
 String mode=request.getParameter("mode");
 //out.println("ccc");
 //如果方法中没有其它参数则读取组织树数据
 if(mode == null){
  /* int OrgId = Integer.parseInt(request.getParameter("id"));
  String str = orgManager.getChildOrg(OrgId, conn);
  out.println(str);
  */
 String str = orgManager.getTree(conn);
 //out.println(str);
 out.println(str);
}else if(mode.equals("createOrg")){
 //如果是createOrg方法则建立一个组织
 int parentOrgId = Integer.parseInt(request.getParameter("parentOrgId"));
 //取出传递来的第一个参数parentOrgId
 int OrgId = orgManager.createOrg(parentOrgId, conn);
 //调用orgManager 类的createOrg方法来建立一个组织
 out.println(OrgId);
 //返回结果
}
conn.close();
}
catch(Exception e){
 e.printStackTrace();
}
%>

 

  六、 后台数据的实现

  1. 数据结构的定义

  这里,我们主要有三个表。一个是组织结构表,一个是人员表person,一个组织人员关联表orgPerson。组织结构表有OrgCode(组织代码)、OrgName(组织名称)、orgId(组织Id), parentOrgId(父Id)。人员表有personCode(人员代码)、personName(人员名称), sex(性别)、personId(人员Id)。orgPerson表有orgId, personId。

  2. 数据库的连接

  WEB应用程序常用MySQL作后台数据库,这是因为MySQL简单、高效。这里我们也用MySQL作为数据库。Java中用jdbc连接数据库。下面是连接数据库的CODE:

public static Connection getConnectionFromPool() throws Exception {
 Context ctx = new InitialContext();
 DataSource ds = (DataSource) ctx.lookup("java:/erpds");
 return ds.getConnection();
}

/**
* 取数据库链接对象
* @return Connection 数据库链接对象
* @throws Exception
*/
/*
public static Connection getDirectConnection() throws Exception {
 Class.forName("com.sybase.jdbc2.jdbc.SybDriver");
 String url = "jdbc:sybase:Tds:19.64.13.16:4100/wydb?charset=iso_1";
 String user = "sa";
 String password = "2860008";
 Connection conn = DriverManager.getConnection(url, user, password);
 return conn;
}
*/

  3. 业务逻辑层的实现

  后台开发我们用Java类来实现。这里我们开发了一个orgNew包,类名为orgManager。此类封装了与数据库操作有关的方法。通过main可调试程序的正确性。

  这里给出了新增加一个组织的全部代码和通过XML取得树结构信息的代码,树结构通过递归实现。

package orgNew;// Java类所打的包
import tool.*;
import java.sql.*;
import java.util.*; // 引用Java类的
public class orgManager {
 public orgManager() { }
 public static void main(String[] args) throws Exception {
  Connection conn = tool.ConnTool.getDirectConnection();// 引用数据访问类
  conn.setAutoCommit(false);

  orgManager orgManager1 = new orgManager();
  orgManager1.createOrg(0, conn); //测试建立组织是否正确
 }
 //建立一个组织
 public static int

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

<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 onload="preLoadImages();doOnLoad();">

  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");//装载树结点数据。数据

展开更多 50%)
分享

猜你喜欢

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

Web开发
利用AJAX+J2EE开发组织机构管理系统

PPT制作精美水晶效果组织机构图

电脑网络
PPT制作精美水晶效果组织机构图

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

用AJAX+J2EE实现一个网上会议室系统

电脑网络
用AJAX+J2EE实现一个网上会议室系统

J2EE开发平台

编程语言 网络编程
J2EE开发平台

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

如何搭建J2EE开发环境

编程语言 网络编程
如何搭建J2EE开发环境

J2EE开发n层应用

编程语言 网络编程
J2EE开发n层应用

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

WPS如何给字体添加纹理效果

WPS如何给字体添加纹理效果

“此操作要求合并单元格都具有相同大小”解决方法

“此操作要求合并单元格都具有相同大小”解决方法
下拉加载更多内容 ↓