<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    細心!用心!耐心!

    吾非文人,乃市井一俗人也,讀百卷書,跨江河千里,故申城一游; 一兩滴辛酸,三四年學業(yè),五六點粗墨,七八筆買賣,九十道人情。

    BlogJava 聯(lián)系 聚合 管理
      1 Posts :: 196 Stories :: 10 Comments :: 0 Trackbacks
    Java 開發(fā)人員與網(wǎng)頁設計人員的橋樑 DWR…呃!我懶得寫簡介了…直接來看看可以做什麼吧!…

    請先到 http://getahead.ltd.uk/dwr/ 下載 dwr.jar,放到WEB-INF/lib下…

    負責處理客戶端請求,並呼叫Java物件的是DWRServlet,DWR其實也有些Model 2的味道,只是View的這一層比較弱,因為放到客戶端的JavaScript應用程式中…

    在web.xml中加入DWRServlet…
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    <?xml version="1.0" encoding="UTF-8"?>
    <web-app id="WebApp_ID" version="2.4"
    xmlns="http://java.sun.com/xml/ns/j2ee"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation=
    "http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
    <display-name>
    ajaxDWR</display-name>
    <servlet>
    <servlet-name>dwr-invoker</servlet-name>
    <servlet-class>uk.ltd.getahead.dwr.DWRServlet</servlet-class>
    <init-param>
    <description>
    </description>
    <param-name>debug</param-name>
    <param-value>true</param-value>
    </init-param>
    </servlet>
    <servlet-mapping>
    <servlet-name>dwr-invoker</servlet-name>
    <url-pattern>/dwr/*</url-pattern>
    </servlet-mapping>
    </web-app>


    接下來寫個簡單的Hello吧!
    1
    2
    3
    4
    5
    6
    7
    package onlyfun.caterpillar;
     
    public class Hello {
    public String hello(String name) {
    return "哈囉!" + name + "!您的第一個DWR!";
    }
    }


    客戶端要呼叫這個Java物件,傳給它參數(shù),而後傳回一個字串,客戶端再顯示這個字串,神奇?其實是要告訴DWRServlet這件事,這需要一個dwr.xml:
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 1.0//EN"
    "http://www.getahead.ltd.uk/dwr/dwr10.dtd">

    <dwr>
    <allow>
    <create creator="new" javascript="Hello">
    <param name="class" value="onlyfun.caterpillar.Hello" />
    </create>
    </allow>
    </dwr>


    creator設定為new,表示使用Hello的無參數(shù)建構子來生成物件,javascript設定為Hello,表示客戶端JavaScript程式可以使用Hello來呼叫對應的onlyfun.caterpillar.Hello物件。

    來寫個客戶端的網(wǎng)頁,當中有一個輸入欄位…
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=BIG5">
    <title>第一個DWR程式</title>
    <script type='text/javascript' src='dwr/interface/Hello.js'></script>
    <script type='text/javascript' src='dwr/engine.js'></script>
    <script type='text/javascript' src='dwr/util.js'></script>
    <script type='text/javascript' src='hello.js'></script>
    </head>
    <body>
     
    <input id="user" type="text" />
    <input type='button' value='哈囉' onclick='hello();' />
     
    <div id="result"></div>
     
    </body>
    </html>


    dwr/interface/Hello.js是由DWRServlet根據(jù)dwr.xml中的設定生成的,engine.js負責客戶端伺服端溝通,util.js是一些好用的JavaScript程式,可以讓您少寫很多JavaScript。

    hello.js是我們自訂的函式,按下按鈕後,會呼叫當中的hello()函式:
    1
    2
    3
    4
    5
    6
    7
    8
    function hello() {
    var user = $('user').value;
    Hello.hello(user, callback);
    }
     
    function callback(msg) {
    DWRUtil.setValue('result', msg);
    }


    ${'user'}取得輸入欄位的DOM物件,value取得當中的欄位值,而後呼叫Hello.hello(),並將value當作參數(shù)傳送… 結果是呼叫Server端的Hello Java物件,當結果傳回後,會呼叫JavaScript的callback函式,DWRUtil的setValue()方法會將傳回的msg設定給指定 id的DOM,結果就是…啥!AJAX的功能在哪…就這個而言就是發(fā)出非同步請求,而回應不用Refresh頁面啦! 



    好啦!這個無聊的Hello DWR可以做啥!…XD

    已經(jīng)可以讓您做個簡單的文字提示功能了…像這個…
    http://caterpillar.onlyfun.net/Gossip/index.html

    把滑鼠指到書的照片上,會顯示提示文字,這些提示文字本身不是存在網(wǎng)頁上的,而是在Server端,當滑鼠指到書上時,會用Request object去抓,然後顯示在框框中…

    當然!我的網(wǎng)站只支援PHP,所以那不是DWR完成的功能,而且我是直接用Request object跟DOM去慢慢刻的…對初學者來說已經(jīng)有些麻煩了…XD

    不過!用DWR就可以很簡單完成這個功能…

    先寫個Java類別吧!會抓properties檔案中的文字訊息,例如…
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    package onlyfun.caterpillar;
     
    import java.util.ResourceBundle;
     
    public class Book {
    private ResourceBundle resource;

    public Book() {
    resource = ResourceBundle.getBundle("book");
    }

    public String getDescription(String key) {
    return resource.getString(key);
    }
    }


    從程式中就知道,它會去抓book_zh_TW.properties的資料,這不是重點啦!只是Java的一個功能,我們要看的是DWR,不過先把book_zh_TW.properties準備好…
    1
    2
    3
    java=Java 學習筆記的介紹 … BlaBla...
    spring=Spring 技術手冊的介紹…BlaBla...
    ajax=Ajax in action 中文版的介紹…


    唔!裏頭是中文字,自己用native2ascii轉換吧…這也不是重點…我們是要看DWR怎麼做到文字提示功能…

    一樣的…要開放這個Book物件,在dwr.xml中…
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 1.0//EN"
    "http://www.getahead.ltd.uk/dwr/dwr10.dtd">

    <dwr>
    <allow>
    <create creator="new" javascript="Book" scope="application">
    <param name="class" value="onlyfun.caterpillar.Book"/>
    </create>
    </allow>
    </dwr>


    scope設定為application,表示這個Book物件在整個應用程式階段都活著。

    然後,客戶端寫個網(wǎng)頁…
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=BIG5">
    <script type='text/javascript' src='dwr/interface/Book.js'></script>
    <script type='text/javascript' src='dwr/engine.js'></script>
    <script type='text/javascript' src='dwr/util.js'></script>
    <script type='text/javascript' src='book.js'></script>
    <title>個人著/譯作</title>
    </head>
    <body>
     
    <div id="ajax" onmouseover="getBookData(this);"
    onmouseout="clearData();"><a
    href="http://www.gotop.com.tw/waweb2004/home/home.aspx?pg=HM010X&bn=AXP011800"><small><img
    style="border: 0px solid ; width: 80px; height: 110px; float: left;"
    alt="Ajax in action 中文版" title="Ajax in action 中文版"
    src="images/ajax_in_action_c.jpg" hspace="10" vspace="2"></small></a></div>
     
    <div id="spring" onmouseover="getBookData(this);"
    onmouseout="clearData();"><a
    href="http://www.gotop.com.tw/waweb2004/home/home.aspx?pg=HM010X&bn=ACL021000"><small><img
    style="border: 0px solid ; width: 80px; height: 110px; float: left;"
    alt="Spring 技術手冊" title="Spring 技術手冊"
    src="images/SpringTech_S.jpg" hspace="10" vspace="2"></small></a></div>
     
    <div id="java" onmouseover="getBookData(this);"
    onmouseout="clearData();"><a
    href="http://www.gotop.com.tw/waweb2004/home/home.aspx?pg=HM010X&bn=ACL020931"><small><img
    style="border: 0px solid ; width: 80px; height: 110px; float: left;"
    alt="Java 學習筆記" title="Java 學習筆記"
    src="images/JavaGossip_Cover_Small.jpg" hspace="10"
    vspace="2"></small></a></div>

    <br/><br/><br/><br/><br/><br/>

    <div id="info"></div>
     
    </body>
    </html>


    重點在於onmouseover跟onmouseout,滑鼠移入與移出時會呼叫的函式,還有最下面的info,抓回來的書籍介紹會放到當中…

    book.js如下,簡單的很…
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    function getBookData(ele) {
    Book.getDescription(ele.id, setBookData);
    }
     
    function setBookData(description) {
    DWRUtil.setValue('info', description);
    }
     
    function clearData() {
    DWRUtil.setValue('info', '');
    }


    程式很簡單,我懶得解釋了…XD

    看一下畫面好了…這是滑鼠移到 Ajax in action中文版 上的介紹畫面…



    Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1186566


    [收藏到我的網(wǎng)摘]   良葛格發(fā)表于 2006年09月06日 20:06:00



    特別推薦:
    posted on 2007-04-16 16:14 張金鵬 閱讀(371) 評論(0)  編輯  收藏 所屬分類: AJAX技術
    主站蜘蛛池模板: 在线观看91精品国产不卡免费| 一级毛片免费不卡| 日韩电影免费在线观看网站| 国产片免费福利片永久| 亚洲精品女同中文字幕| 成年轻人网站色免费看| 亚洲人成影院在线高清| 成人黄色免费网址| 亚洲av片不卡无码久久| 91在线视频免费91| 中文字幕在线观看亚洲视频| 国产精品免费观看久久| 亚洲欧美国产精品专区久久| 国产成人在线免费观看| 在线看片免费人成视频播| 亚洲自偷自偷在线成人网站传媒 | 亚洲AV无码成人精品区大在线| 久久夜色精品国产噜噜亚洲AV| 日韩a毛片免费观看| 免费A级毛片无码A∨男男| 美女被免费视频网站| 亚洲男人第一无码aⅴ网站| 亚洲一区二区三区免费| 亚洲精品无码av人在线观看| 国产免费一区二区三区不卡| 亚洲综合成人婷婷五月网址| 国产精品视频免费一区二区三区| 久久国产精品国产自线拍免费 | 亚洲三级在线视频| 亚洲国产另类久久久精品小说| 拔擦拔擦8x华人免费久久| 精品无码人妻一区二区免费蜜桃| 亚洲av永久无码精品三区在线4 | 免费a在线观看播放| 无码中文字幕av免费放| 免费视频精品一区二区三区| 精品福利一区二区三区免费视频 | 亚洲视频在线免费| 亚洲人成色99999在线观看| 水蜜桃亚洲一二三四在线| 51在线视频免费观看视频|