Java 開發(fā)人員與網(wǎng)頁設(shè)計(jì)人員的橋樑 DWR…呃!我懶得寫簡介了…直接來看看可以做什麼吧!…
請(qǐng)先到 http://getahead.ltd.uk/dwr/ 下載 dwr.jar,放到WEB-INF/lib下…
負(fù)責(zé)處理客戶端請(qǐng)求,並呼叫Java物件的是DWRServlet,DWR其實(shí)也有些Model 2的味道,只是View的這一層比較弱,因?yàn)榉诺娇蛻舳说腏avaScript應(yīng)用程式中…
在web.xml中加入DWRServlet…
接下來寫個(gè)簡單的Hello吧!
客戶端要呼叫這個(gè)Java物件,傳給它參數(shù),而後傳回一個(gè)字串,客戶端再顯示這個(gè)字串,神奇?其實(shí)是要告訴DWRServlet這件事,這需要一個(gè)dwr.xml:
creator設(shè)定為new,表示使用Hello的無參數(shù)建構(gòu)子來生成物件,javascript設(shè)定為Hello,表示客戶端JavaScript程式可以使用Hello來呼叫對(duì)應(yīng)的onlyfun.caterpillar.Hello物件。
來寫個(gè)客戶端的網(wǎng)頁,當(dāng)中有一個(gè)輸入欄位…
dwr/interface/Hello.js是由DWRServlet根據(jù)dwr.xml中的設(shè)定生成的,engine.js負(fù)責(zé)客戶端伺服端溝通,util.js是一些好用的JavaScript程式,可以讓您少寫很多JavaScript。
hello.js是我們自訂的函式,按下按鈕後,會(huì)呼叫當(dāng)中的hello()函式:
${'user'}取得輸入欄位的DOM物件,value取得當(dāng)中的欄位值,而後呼叫Hello.hello(),並將value當(dāng)作參數(shù)傳送… 結(jié)果是呼叫Server端的Hello Java物件,當(dāng)結(jié)果傳回後,會(huì)呼叫JavaScript的callback函式,DWRUtil的setValue()方法會(huì)將傳回的msg設(shè)定給指定 id的DOM,結(jié)果就是…啥!AJAX的功能在哪…就這個(gè)而言就是發(fā)出非同步請(qǐng)求,而回應(yīng)不用Refresh頁面啦!

好啦!這個(gè)無聊的Hello DWR可以做啥!…XD
已經(jīng)可以讓您做個(gè)簡單的文字提示功能了…像這個(gè)…
http://caterpillar.onlyfun.net/Gossip/index.html
把滑鼠指到書的照片上,會(huì)顯示提示文字,這些提示文字本身不是存在網(wǎng)頁上的,而是在Server端,當(dāng)滑鼠指到書上時(shí),會(huì)用Request object去抓,然後顯示在框框中…
當(dāng)然!我的網(wǎng)站只支援PHP,所以那不是DWR完成的功能,而且我是直接用Request object跟DOM去慢慢刻的…對(duì)初學(xué)者來說已經(jīng)有些麻煩了…XD
不過!用DWR就可以很簡單完成這個(gè)功能…
先寫個(gè)Java類別吧!會(huì)抓properties檔案中的文字訊息,例如…
從程式中就知道,它會(huì)去抓book_zh_TW.properties的資料,這不是重點(diǎn)啦!只是Java的一個(gè)功能,我們要看的是DWR,不過先把book_zh_TW.properties準(zhǔn)備好…
唔!裏頭是中文字,自己用native2ascii轉(zhuǎn)換吧…這也不是重點(diǎn)…我們是要看DWR怎麼做到文字提示功能…
一樣的…要開放這個(gè)Book物件,在dwr.xml中…
scope設(shè)定為application,表示這個(gè)Book物件在整個(gè)應(yīng)用程式階段都活著。
然後,客戶端寫個(gè)網(wǎng)頁…
重點(diǎn)在於onmouseover跟onmouseout,滑鼠移入與移出時(shí)會(huì)呼叫的函式,還有最下面的info,抓回來的書籍介紹會(huì)放到當(dāng)中…
book.js如下,簡單的很…
程式很簡單,我懶得解釋了…XD
看一下畫面好了…這是滑鼠移到 Ajax in action中文版 上的介紹畫面…

請(qǐng)先到 http://getahead.ltd.uk/dwr/ 下載 dwr.jar,放到WEB-INF/lib下…
負(fù)責(zé)處理客戶端請(qǐng)求,並呼叫Java物件的是DWRServlet,DWR其實(shí)也有些Model 2的味道,只是View的這一層比較弱,因?yàn)榉诺娇蛻舳说腏avaScript應(yīng)用程式中…
在web.xml中加入DWRServlet…
1 |
<?xml version="1.0" encoding="UTF-8"?> |
接下來寫個(gè)簡單的Hello吧!
1 |
package onlyfun.caterpillar; |
客戶端要呼叫這個(gè)Java物件,傳給它參數(shù),而後傳回一個(gè)字串,客戶端再顯示這個(gè)字串,神奇?其實(shí)是要告訴DWRServlet這件事,這需要一個(gè)dwr.xml:
1 |
<?xml version="1.0" encoding="UTF-8"?> |
creator設(shè)定為new,表示使用Hello的無參數(shù)建構(gòu)子來生成物件,javascript設(shè)定為Hello,表示客戶端JavaScript程式可以使用Hello來呼叫對(duì)應(yīng)的onlyfun.caterpillar.Hello物件。
來寫個(gè)客戶端的網(wǎng)頁,當(dāng)中有一個(gè)輸入欄位…
1 |
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> |
dwr/interface/Hello.js是由DWRServlet根據(jù)dwr.xml中的設(shè)定生成的,engine.js負(fù)責(zé)客戶端伺服端溝通,util.js是一些好用的JavaScript程式,可以讓您少寫很多JavaScript。
hello.js是我們自訂的函式,按下按鈕後,會(huì)呼叫當(dāng)中的hello()函式:
1 |
function hello() { |
${'user'}取得輸入欄位的DOM物件,value取得當(dāng)中的欄位值,而後呼叫Hello.hello(),並將value當(dāng)作參數(shù)傳送… 結(jié)果是呼叫Server端的Hello Java物件,當(dāng)結(jié)果傳回後,會(huì)呼叫JavaScript的callback函式,DWRUtil的setValue()方法會(huì)將傳回的msg設(shè)定給指定 id的DOM,結(jié)果就是…啥!AJAX的功能在哪…就這個(gè)而言就是發(fā)出非同步請(qǐng)求,而回應(yīng)不用Refresh頁面啦!

好啦!這個(gè)無聊的Hello DWR可以做啥!…XD
已經(jīng)可以讓您做個(gè)簡單的文字提示功能了…像這個(gè)…
http://caterpillar.onlyfun.net/Gossip/index.html
把滑鼠指到書的照片上,會(huì)顯示提示文字,這些提示文字本身不是存在網(wǎng)頁上的,而是在Server端,當(dāng)滑鼠指到書上時(shí),會(huì)用Request object去抓,然後顯示在框框中…
當(dāng)然!我的網(wǎng)站只支援PHP,所以那不是DWR完成的功能,而且我是直接用Request object跟DOM去慢慢刻的…對(duì)初學(xué)者來說已經(jīng)有些麻煩了…XD
不過!用DWR就可以很簡單完成這個(gè)功能…
先寫個(gè)Java類別吧!會(huì)抓properties檔案中的文字訊息,例如…
1 |
package onlyfun.caterpillar; |
從程式中就知道,它會(huì)去抓book_zh_TW.properties的資料,這不是重點(diǎn)啦!只是Java的一個(gè)功能,我們要看的是DWR,不過先把book_zh_TW.properties準(zhǔn)備好…
1 |
java=Java 學(xué)習(xí)筆記的介紹 … BlaBla... |
唔!裏頭是中文字,自己用native2ascii轉(zhuǎn)換吧…這也不是重點(diǎn)…我們是要看DWR怎麼做到文字提示功能…
一樣的…要開放這個(gè)Book物件,在dwr.xml中…
1 |
<?xml version="1.0" encoding="UTF-8"?> |
scope設(shè)定為application,表示這個(gè)Book物件在整個(gè)應(yīng)用程式階段都活著。
然後,客戶端寫個(gè)網(wǎng)頁…
1 |
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> |
重點(diǎn)在於onmouseover跟onmouseout,滑鼠移入與移出時(shí)會(huì)呼叫的函式,還有最下面的info,抓回來的書籍介紹會(huì)放到當(dāng)中…
book.js如下,簡單的很…
1 |
function getBookData(ele) { |
程式很簡單,我懶得解釋了…XD
看一下畫面好了…這是滑鼠移到 Ajax in action中文版 上的介紹畫面…

Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1186566
[收藏到我的網(wǎng)摘] 良葛格發(fā)表于 2006年09月06日 20:06:00
特別推薦:
- 專業(yè)的Java開源技術(shù)培訓(xùn)
藍(lán)點(diǎn)世紀(jì)外企Java軟件工程師培訓(xùn)業(yè)余班,助你實(shí)現(xiàn) 月薪1000-6000元的飛躍! ajax - 每天50元!百萬用戶等你來!
廣告價(jià)格高,預(yù)算有限,產(chǎn)品推不出去,怎么辦? Tag廣告-靈活控制成本,直達(dá)目標(biāo)用戶!經(jīng)濟(jì)、實(shí)惠 ajax - 把握最前端的技術(shù) 獲得最搶手的職業(yè)
極限編程方法挖掘您架構(gòu)師的潛質(zhì)和拓展能力 東方標(biāo)準(zhǔn) 國際軟件工程師就業(yè)班 4月開課安排 ajax - AJAX學(xué)習(xí)必備的三本書
AJAX圖書十幾本?那本書最適合您? CSDN讀書頻道獨(dú)家奉獻(xiàn) ajax - 《Ajax基礎(chǔ)教程》六章連載中
詳解Ajax開發(fā)工具與JavaScript測試 CSDN讀書頻道獨(dú)家奉獻(xiàn) ajax