財(cái)哥的地盤

          家窮人丑,一米四九

            BlogJava :: 首頁(yè) :: 聯(lián)系 :: 聚合  :: 管理
            21 Posts :: 19 Stories :: 3 Comments :: 0 Trackbacks
          也許朋友們會(huì)以為這是DWR官方發(fā)布的什么幫助,但非常遺憾這不是。現(xiàn)在不少朋友在使用DWR開(kāi)發(fā)項(xiàng)目,我也是其中之一,但苦于關(guān)于DWR的幫助文檔實(shí)在太少,很多問(wèn)題都不得不自己去鉆研DWR的源碼才能解決或理解。經(jīng)過(guò)一段時(shí)間的苦苦鉆研,總結(jié)出那么一點(diǎn)點(diǎn)心得,現(xiàn)在從DWR源碼實(shí)現(xiàn)的角度詳細(xì)講解DWR的使用,寫出來(lái)與大家分享。今天我談一談如何編寫通用的單行編輯框

          當(dāng)我們需要編輯某行數(shù)據(jù)的時(shí)候,可以將該行的數(shù)據(jù)設(shè)置到一個(gè)已經(jīng)設(shè)計(jì)好的單行編輯框中進(jìn)行編輯。在編輯完成以后,點(diǎn)擊“保存”按鈕,DWR可以采用ajax的方式訪問(wèn)服務(wù)器,將數(shù)據(jù)保存到數(shù)據(jù)庫(kù)中。怎樣設(shè)計(jì)一個(gè)單行編輯框呢?讓我們一步一步來(lái)完成吧。

          1、設(shè)計(jì)頁(yè)面。

          設(shè)計(jì)好一個(gè)單行編輯框的頁(yè)面,為值對(duì)象中的每一個(gè)屬性設(shè)計(jì)一個(gè)數(shù)據(jù)輸入框,如單行文本框、多行編輯框、下拉框、單選框等等。設(shè)計(jì)這些數(shù)據(jù)輸入框的同時(shí)應(yīng)當(dāng)將它們的id設(shè)置成與值對(duì)象對(duì)應(yīng)的屬性名相同的名稱。這里我想特別說(shuō)明的是下拉框,因?yàn)橄吕蛑械南吕糠謶?yīng)當(dāng)是一個(gè)從數(shù)據(jù)庫(kù)中查出來(lái)的下拉列表。DWR為下拉框設(shè)計(jì)了一個(gè)非常便利的函數(shù)addOptions(),函數(shù)addOptions的完整寫法如下
          Js代碼 復(fù)制代碼
          1. addoptions(eleid, data, valueprop, textprop);  
           在該函數(shù)中,eleid是下拉框的iddata是下拉框需要顯示的下拉列表的數(shù)據(jù)集,它通常需要包含至少兩行數(shù)據(jù),一行是下拉框value部分的數(shù)據(jù),即需要存數(shù)據(jù)庫(kù)的數(shù)據(jù),另一行是下拉框text部分的數(shù)據(jù),即僅僅用于在下拉列表中顯示的數(shù)據(jù)。比如,我們有一個(gè)選擇部門的下拉框,value部分對(duì)應(yīng)的應(yīng)當(dāng)部門編號(hào),而text部分應(yīng)當(dāng)是部門名稱。清楚了datavalueproptextprop就好說(shuō)了,valueprop就是value部分的屬性名,textprop就是text部分的屬性名。因此,寫一個(gè)選擇部門的下拉框應(yīng)當(dāng)這樣寫:
          Js代碼 復(fù)制代碼
          1. DepartmentBus.findDepartment(   
          2.     function(resultset){       
          3.         addoptions(‘department’,resultset.collection,   
          4.             ’departmentId’,’departmentName’);});  
          DepartmentBus.findDepartment(
          function(resultset){
          addoptions(‘department’,resultset.collection,
          ’departmentId’,’departmentName’);});
          

            另外一個(gè)關(guān)鍵的問(wèn)題我想特別提一下,就是值對(duì)象的主鍵。我在設(shè)計(jì)hibernate的值對(duì)象的時(shí)候倡導(dǎo)的是使用無(wú)意義的主鍵。既然是無(wú)意義的主鍵,那么我們不應(yīng)當(dāng)將主鍵值展示給用戶。因此我在設(shè)計(jì)頁(yè)面的時(shí)候通常是將主鍵對(duì)應(yīng)的標(biāo)簽設(shè)計(jì)成一個(gè)hidden標(biāo)簽。如果主鍵標(biāo)簽為空,在提交數(shù)據(jù)保存的時(shí)候,hibernate將執(zhí)行插入操作;如果不為空,執(zhí)行的將是更新操作。因此,通常不需要分別設(shè)計(jì)插入頁(yè)面和更新頁(yè)面,可以將它們合二為一(一些因特殊原因必須將插入頁(yè)面和更新頁(yè)面拆開(kāi)來(lái)編寫的情況應(yīng)當(dāng)另當(dāng)別論)。

          2、設(shè)計(jì)清除函數(shù)

          如果你需要設(shè)計(jì)一個(gè)添加功能,則需要顯示一個(gè)沒(méi)有顯示任何值的空單行編輯框。然而使用DWR設(shè)計(jì)頁(yè)面,我們的思維需要發(fā)生一個(gè)轉(zhuǎn)變,那就是不要隨便刷新頁(yè)面。什么意思呢?當(dāng)你打開(kāi)一個(gè)單行編輯框添加一條數(shù)據(jù)并保存以后,又需要添加另一條數(shù)據(jù)。如果不刷新頁(yè)面,則該頁(yè)面此時(shí)還依然顯示的是上一條數(shù)據(jù)的內(nèi)容,我們就需要設(shè)計(jì)一個(gè)頁(yè)面清除函數(shù)。如果我們?cè)?/span>dwr.xml文件中是一個(gè)一個(gè)注冊(cè)值對(duì)象,那么寫清除函數(shù)就非常簡(jiǎn)單了。具體編輯如下:
          Js代碼 復(fù)制代碼
          1. var department = new Department();   
          2. dwr.util.setValues(department);  
          var department = new Department();
          dwr.util.setValues(department);

           第一行產(chǎn)生一個(gè)空值對(duì)象,第二行使用setValues()將頁(yè)面清空。

          3、設(shè)計(jì)編輯函數(shù)

          當(dāng)我們?cè)诹斜盹@示框中選擇了某行并點(diǎn)擊“編輯”按鈕以后,需要一個(gè)編輯函數(shù)將該行的數(shù)據(jù)設(shè)置到單行編輯框中。用DWR怎樣設(shè)計(jì)編輯函數(shù)呢?前面提到,在列表顯示框裝載查詢結(jié)果集的時(shí)候,我們同時(shí)也將結(jié)果集放置到了一個(gè)叫objCache頁(yè)面端數(shù)據(jù)緩存中。當(dāng)用戶點(diǎn)擊“編輯”按鈕時(shí),需要將該行的行好以參數(shù)的形式傳遞給編輯函數(shù),然后編輯函數(shù)將到objCache中取得該行的值對(duì)象,最后使用setValues()將該值對(duì)象設(shè)置到單行編輯框中。

          4、設(shè)計(jì)保存函數(shù)

          當(dāng)編輯數(shù)據(jù)完成以后,點(diǎn)擊“保存”按鈕以后,需要執(zhí)行一個(gè)保存函數(shù)來(lái)執(zhí)行保存。在設(shè)計(jì)保存函數(shù)的時(shí)候,首先需要從頁(yè)面中取出數(shù)據(jù)并放置到值對(duì)象中。為了完成該功能,DWR提供了getValues()函數(shù)。在使用該函數(shù)的時(shí)候,我們必須寫產(chǎn)生一個(gè)空值對(duì)象,然后將該對(duì)象作為參數(shù)傳遞給getValues(),則頁(yè)面中的數(shù)據(jù)就植入到了該對(duì)象中。最后,使用DWR的特有方式,調(diào)用服務(wù)器端的java對(duì)象中的函數(shù),執(zhí)行保存。在執(zhí)行保存的過(guò)程這,DWR還專門提供了事務(wù)處理的功能,當(dāng)然我從來(lái)沒(méi)有測(cè)試過(guò)該事務(wù)處理的能力。總結(jié)保存函數(shù)應(yīng)當(dāng)如下編寫:
          Js代碼 復(fù)制代碼
          1. var department = new Department();       
          2. dwr.util.getValues(department);       
          3. dwr.engine.beginBatch();   
          4. DepartmentBus.updateDepartment(department);   
          5. dwr.engine.endBatch();   
          6. objCache[curid] = obj;  
          var department = new Department();
          dwr.util.getValues(department);
          dwr.engine.beginBatch();
          DepartmentBus.updateDepartment(department);
          dwr.engine.endBatch();
          objCache[curid] = obj;

           回顧保存函數(shù),我們可以抽象出部分代碼,以便簡(jiǎn)化保存函數(shù)的編寫并提高代碼復(fù)用度。代碼中的第2356行都可以抽象成一個(gè)通用的函數(shù)進(jìn)行編寫。而代碼中的14行則是個(gè)性化的代碼,應(yīng)當(dāng)在具體編寫每個(gè)功能的時(shí)候分別去實(shí)現(xiàn)。也就是說(shuō)保存函數(shù)被我分成了通用函數(shù)和具體實(shí)現(xiàn)函數(shù)兩部分,具體的實(shí)現(xiàn)見(jiàn)我的示例。

          5、設(shè)計(jì)刪除函數(shù)

          當(dāng)我們?cè)诹斜盹@示框中選擇了某行并點(diǎn)擊“刪除”按鈕的時(shí)候,我們需要設(shè)計(jì)一個(gè)刪除函數(shù)來(lái)刪除該行數(shù)據(jù)。刪除函數(shù)的設(shè)計(jì)與保存函數(shù)的設(shè)計(jì)比較近似,這里我就不再累贅了,朋友們自己思考吧。

          posted on 2008-04-02 14:19 楊景 閱讀(328) 評(píng)論(0)  編輯  收藏 所屬分類: javaScript
          主站蜘蛛池模板: 滦南县| 乃东县| 朝阳区| 尚志市| 临潭县| 阿勒泰市| 沙雅县| 永清县| 涟水县| 聂拉木县| 张家港市| 和田市| 沙雅县| 班玛县| 清原| 德惠市| 乌拉特前旗| 宣恩县| 长沙县| 星子县| 招远市| 灵寿县| 子洲县| 辉县市| 垦利县| 孝义市| 珲春市| 台前县| 莱西市| 柯坪县| 潍坊市| 中西区| 东莞市| 桓台县| 贵阳市| 台东县| 静乐县| 罗山县| 丽江市| 西和县| 金溪县|