DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> AJAX入門 >> AJAX詳解 >> 利用AJAX+J2EE開發組織機構管理系統(1).
利用AJAX+J2EE開發組織機構管理系統(1).
編輯:AJAX詳解     
一、 概述

  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" 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>之間鍵接我們的與樹有關的文件, 代碼如下:

<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方法實現初始化
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved