一、 概述 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 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");//裝載樹結點資料。資料來源如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方法實現初始化。 <body onload="init();"> init方法實現如下: function init(){ //定義personDom為一個XMLDOM'對象 personDom= new ActiveXObject('Microsoft.XMLDOM'); personDom.async = false; //定義stylesheet為一個XMLDOM'對象,且stylesheet為personDom確定顯示風格 stylesheet = new ActiveXObject('Microsoft.XMLDOM'); stylesheet.async = false; stylesheet.load("addOrgPerson.xsl"); //裝載stylesheet的風格定義檔案 //裝載組織類型資料 var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP"); xmlhttp.open("POST","Org.jsp?mode=GetOrgType", false); xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); xmlhttp.send(); retXml=xmlhttp.responseText; // alert(retXml); //把組織類型插入下拉式清單控制項中 var OrgDoc = new ActiveXObject('Microsoft.XMLDOM'); OrgDoc.async = false; OrgDoc.loadXML(retXml); var root = OrgDoc.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" |