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

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

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

    幸せのちから

    平凡的世界
    看似平常實(shí)崎嶇
    成如容易卻艱辛

    extremeComponents使用AJAX 指南

    AJAX 指南

    進(jìn)行中...


    在eXtremeTable中使用AJAX非常簡(jiǎn)單,對(duì)現(xiàn)有功能的擴(kuò)展也非常方便。 AJAX整合一個(gè)最強(qiáng)大的地方是它不需要整合。你可以自由地使用任何你想要使用的AJAX工具包。所有你要做的就是:當(dāng)表的action被調(diào)用時(shí),告訴 eXtremeTable使用什么javascript。表的actions包括:過(guò)濾、排序、分頁(yè)、顯示的行數(shù)和導(dǎo)出。

    在我自己的示例中我將使用非常酷的DWR工具包。DWR 需要的粘合代碼非常少,這樣我們只需要關(guān)注如何構(gòu)建表。你可以通過(guò)本站示例看到效果!

    Assembler Example

    本示例中將需要安裝DWR工具包,創(chuàng)建POJO來(lái)構(gòu)造表并創(chuàng)建包含eXtremeTable的JSP頁(yè)面。

    安裝DWR

    首先要做的就是下載DWR工具包。你應(yīng)該瀏覽網(wǎng)站的使用說(shuō)明,不過(guò)下面是我讓它符合我的需要來(lái)工作所進(jìn)行的操作:

    • 將dwr-1.1.jar拷貝到WEB-INF/lib目錄
    • 在WEB-INF目錄下創(chuàng)建一個(gè)dwr.xml文件
    <!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="Assembler">
    <param name="class" value="org.extremesite.controller.Assembler"/>
    <include method="getTable"/>
    </create>
    </allow>
    <signatures>
    <![CDATA[
    import java.util.Map;
    import java.util.List;
    import org.extremesite.controller.Assembler;
    import javax.servlet.http.HttpServletRequest;
    Assembler.getTable(Map<String, List> parameterMap, HttpServletRequest request);
    ]]>
    </signatures>
    </dwr>

    簡(jiǎn)而言之(In a nutshell)創(chuàng)建(create)標(biāo)簽允許當(dāng)方法被調(diào)用時(shí),參照構(gòu)建表需要的POJO。簽名(signature)標(biāo)簽聲明了被調(diào)用方法使用的實(shí)際 類型。 本示例的Assembler類的getTable方法將通過(guò)傳入一個(gè)Map(包含form參數(shù))和HttpServletRequest。

    • 在WEB-INF/web.xml中對(duì)DWR servlet進(jìn)行聲明
      <servlet>
    <servlet-name>dwr-invoker</servlet-name>
    <display-name>DWR Servlet</display-name>
    <servlet-class>uk.ltd.getahead.dwr.DWRServlet</servlet-class>
    <init-param>
    <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>

    以上就完成了DWR servlet的設(shè)置,它被用來(lái)調(diào)用你的POJO。除了設(shè)置它,你不需要對(duì)這個(gè)servlet有更多的了解。

    創(chuàng)建POJO

    DWR使用(works with)POJOs。這個(gè)非常符合我們的需要,因?yàn)閑XtremeTable有足夠的API使用Jsp標(biāo)簽來(lái)構(gòu)造表。實(shí)際上,JSP標(biāo)簽只不過(guò)是eXtremeTable Java API的前端。首先,我將展示構(gòu)造表的方法:

    public class Assembler {
    private Object build(TableModel model, Collection presidents) throws Exception {
    Table table = model.getTableInstance();
    table.setTableId("assembler");
    table.setItems(presidents);
    table.setAction(model.getContext().getContextPath() + "/assembler.run");
    table.setTitle("Presidents");
    table.setOnInvokeAction("buildTable('assembler')");
    model.addTable(table);

    Export export = model.getExportInstance();
    export.setView(TableConstants.VIEW_XLS);
    export.setViewResolver(TableConstants.VIEW_XLS);
    export.setImageName(TableConstants.VIEW_XLS);
    export.setText(TableConstants.VIEW_XLS);
    export.setFileName("output.xls");
    model.addExport(export);

    Row row = model.getRowInstance();
    row.setHighlightRow(Boolean.FALSE);
    model.addRow(row);

    Column columnName = model.getColumnInstance();
    columnName.setProperty("fullName");
    columnName.setIntercept((AssemblerIntercept.class).getName());
    model.addColumn(columnName);

    Column columnNickName = model.getColumnInstance();
    columnNickName.setProperty("nickName");
    model.addColumn(columnNickName);

    Column columnTerm = model.getColumnInstance();
    columnTerm.setProperty("term");
    model.addColumn(columnTerm);

    Column columnBorn = model.getColumnInstance();
    columnBorn.setProperty("born");
    columnBorn.setCell(TableConstants.DATE);
    model.addColumn(columnBorn);

    Column columnDied = model.getColumnInstance();
    columnDied.setProperty("died");
    columnDied.setCell(TableConstants.DATE);
    model.addColumn(columnDied);

    Column columnCareer = model.getColumnInstance();
    columnCareer.setProperty("career");
    model.addColumn(columnCareer);

    return model.assemble();
    }
    }

    上面的大部分代碼是自解釋性的,你將在下面看到如何構(gòu)造一個(gè)TableModel,但是首先你應(yīng)該注意到TableModel是構(gòu)造表時(shí)需要交互的 唯一對(duì)象。構(gòu)造表的第一步就是使用TableModel來(lái)創(chuàng)建Table、Row、Column和Export。 一旦你創(chuàng)建了一個(gè)model對(duì)象,你只需要將它添加到model中。除非你將它添加到TableModel,否則的話model將不會(huì)是用它。所有東西已 經(jīng)構(gòu)建好后,你只需要調(diào)用model.assemble()方法來(lái)構(gòu)造表了。

    可能table.setOnInvokeAction("buildTable('assembler')");是最有趣的調(diào)用。當(dāng)你使用表的actions(翻頁(yè)、過(guò)濾、排序......),這個(gè)javascript方法將被調(diào)用。如果表的onInvokeAction空白,則默認(rèn)的javascript方法將被提交(submit) ,正如你所期望的那樣。

    Assembler類的另一個(gè)方法---getTable():

    public class Assembler {
    public String getTable(Map parameterMap, HttpServletRequest request) {
    WebApplicationContext webApplicationContext = WebApplicationContextUtils.getWebApplicationContext(request.getSession().getServletContext());

    PresidentsDao presidentsDao = (PresidentsDao) webApplicationContext.getBean("presidentsDao");
    Collection presidents = presidentsDao.getPresidents();

    Context context = null;
    if (parameterMap == null) {
    context = new HttpServletRequestContext(request);
    } else {
    context = new HttpServletRequestContext(request, parameterMap);
    }

    TableModel model = new TableModelImpl(context);
    try {
    return build(model, presidents).toString();
    } catch (Exception e) {
    e.printStackTrace();
    }

    return "";
    }
    }

    這個(gè)方法調(diào)用比較頻繁,它執(zhí)行雙重職責(zé)。它需要被Controller(如果使用Spring的話)在第一次調(diào)用,如果使用Struts就等同于Action類。 隨后, 當(dāng)使用AJAX時(shí),這個(gè)方法也需要被調(diào)用,但是這次將傳入一個(gè)定制的parameterMap。parameterMap將包含eXtremeTable使用AJAX需要的所有參數(shù)。當(dāng)你看了 Controller和JSP后,這點(diǎn)將更加清晰。

    Controller

    public class AssemblerController extends AbstractController {
    public String successView;

    public void setSuccessView(String successView) {
    this.successView = successView;
    }

    protected ModelAndView handleRequestInternal(HttpServletRequest request, HttpServletResponse response) throws Exception {
    ModelAndView mv = new ModelAndView(successView);
    Assembler assembler = new Assembler();
    Object viewData = assembler.getTable(null, request);
    request.setAttribute("assembler", viewData);
    return mv;
    }
    }

    controller在被第一次調(diào)用時(shí)來(lái)構(gòu)建表。它調(diào)用POJO并將表傳給request。注意空值(null)如何使用parameterMap傳輸。這是因?yàn)榈谝淮伪肀粯?gòu)造時(shí),沒(méi)有對(duì)應(yīng)表需要知道的actions。

    JSP

    通過(guò)引入(importing)合適的javascript文件來(lái)開(kāi)始構(gòu)建JSP頁(yè)面。唯一需要包含進(jìn)工程的javascript文件是extremecomponents.js,其它的javascript文件申明都是DWR使用的。

      <script type="text/javascript" src="<c:url value="/dwr/interface/Assembler.js"/>"></script>
    <script type="text/javascript" src="<c:url value="/dwr/engine.js"/>"></script>
    <script type="text/javascript" src="<c:url value="/dwr/util.js"/>"></script>
    <script type="text/javascript" src="<c:url value="/js/extremecomponents.js"/>"></script>

    接著,插入鉤子(hook)來(lái)顯示表,div被用來(lái)調(diào)用innerHtml并構(gòu)建新的標(biāo)簽。

      <div id="tableDiv">
    <c:out value="${assembler}" escapeXml="false"/>
    </div>

    最后,添加javascript來(lái)調(diào)用DWR的鉤子(hooks)。

    <script type="text/javascript">
    function buildTable(form) {
    var parameterMap = getParameterMap(form);
    Assembler.getTable(parameterMap, showTable);
    }

    function showTable(table) {
    document.getElementById('tableDiv').innerHTML=table;
    }
    </script>

    getParameterMap()方法包含在extremecomponents.js文件中,將的到所有的form參數(shù)。你需要傳入一個(gè) form id的參照。記住,eXtremeTable本質(zhì)上是一個(gè)form組建,tableid作為form id使用。默認(rèn)的tableId為ec,但是你通常想要設(shè)置tableId,以示大家能更容易閱讀你的代碼。你將使用parameterMap調(diào)用 POJO的getTable方法。showTable是一個(gè)callback告訴DWR當(dāng)從getTable()方法返回時(shí)將調(diào)用什么操作。

    結(jié)論

    本指南描述了在eXtremeTable中使用AJAX所需要的步驟。需要留心的一個(gè)主要事情是沒(méi)有和AJAX發(fā)生實(shí)際整合。當(dāng)表的actions 被使用是,你只需要簡(jiǎn)單地告訴eXtremeTable什么javascript將被調(diào)yong。另一個(gè)事情是,通過(guò)本示例我們可以知道DWR工具包使用 POJOs并能夠簡(jiǎn)單地被任何框架使用。

    posted on 2006-03-27 17:09 Lucky 閱讀(6486) 評(píng)論(10)  編輯  收藏 所屬分類: extremeComponents

    評(píng)論

    # re: extremeComponents使用AJAX 指南 2006-03-28 15:06 差沙

    官網(wǎng)上面的是你翻譯的么??多了多大的工作,多謝。。

    不過(guò)總覺(jué)得現(xiàn)在這個(gè)ajax實(shí)現(xiàn)的不倫不類,要是用ajaxanywhere來(lái)實(shí)現(xiàn)的話,根本就不用改現(xiàn)在代碼。  回復(fù)  更多評(píng)論   

    # re: extremeComponents使用AJAX 指南 2006-03-28 15:13 Lucky

    官網(wǎng)上的是我翻譯的,方便大家。

    對(duì)于AJAX,我是一點(diǎn)都不懂,不過(guò)我感覺(jué)現(xiàn)在的實(shí)現(xiàn)對(duì)于原來(lái)的代碼來(lái)說(shuō),需要的更改不是太大。  回復(fù)  更多評(píng)論   

    # re: extremeComponents使用AJAX 指南 2006-03-28 21:41 fanse

    DWR的確是個(gè)不錯(cuò)的工具

    歡迎訪問(wèn)http://www.shuangzixing.net  回復(fù)  更多評(píng)論   

    # re: extremeComponents使用AJAX 指南 2006-03-29 12:47 Lucky

    雙子星http://www.shuangzixing.net/ 挺不錯(cuò)的
    理念有點(diǎn)和openfans類似
    http://www.openfans.net/main.html  回復(fù)  更多評(píng)論   

    # re: extremeComponents使用AJAX 指南 2006-07-25 15:20 nbaertuo@21cn.com

    怎么加一個(gè)下來(lái)菜單列 ?
    菜單的內(nèi)容還可以是動(dòng)態(tài)的嗎?  回復(fù)  更多評(píng)論   

    # re: extremeComponents使用AJAX 指南 2006-11-02 12:32 phoenix[匿名]

    現(xiàn)在的代碼如果改用這種AJAX,幾乎所有代碼都要重寫(xiě),而且不可復(fù)用,這玩意兒只能拿來(lái)當(dāng)玩具,在實(shí)際項(xiàng)目中幾乎不可用。  回復(fù)  更多評(píng)論   

    # 歡迎大家去試用一個(gè)全新的extremeComponents增強(qiáng)版: EC Side. 2007-01-29 17:34 fins

    歡迎大家去試用一個(gè)全新的extremeComponents增強(qiáng)版: EC Side.
    ECSide發(fā)布地址:
    1.1版本: http://fins.javaeye.com/blog/51068
    1.0版本: http://fins.javaeye.com/blog/40190
    ECSide圈子:
    http://ecside.javaeye.com/
    ECSide綜合討論專用帖
    http://fins.javaeye.com/blog/48723
      回復(fù)  更多評(píng)論   

    # re: extremeComponents使用AJAX 指南 2007-11-03 13:33 大媽

    學(xué)習(xí)  回復(fù)  更多評(píng)論   

    # re: extremeComponents使用AJAX 指南 2007-11-27 00:02 專注java開(kāi)源

    多謝了  回復(fù)  更多評(píng)論   

    # re: extremeComponents使用AJAX 指南 2009-11-23 13:42 bolo

    如果我想使用jquery來(lái)實(shí)現(xiàn)的話,需要修改哪些地方?  回復(fù)  更多評(píng)論   

    <2006年3月>
    2627281234
    567891011
    12131415161718
    19202122232425
    2627282930311
    2345678

    導(dǎo)航

    隨筆分類(125)

    文章分類(5)

    日本語(yǔ)

    搜索

    積分與排名

    最新隨筆

    最新評(píng)論

    主站蜘蛛池模板: 日本免费精品一区二区三区 | 亚洲深深色噜噜狠狠爱网站| 国产久爱免费精品视频| 亚洲an天堂an在线观看| 久久99九九国产免费看小说| 美女啪啪网站又黄又免费| 久久噜噜噜久久亚洲va久| 妞干网手机免费视频| 国产精品青草视频免费播放| 4480yy私人影院亚洲| 免费播放特黄特色毛片| 99re免费视频| 免费一级全黄少妇性色生活片 | 亚洲性无码AV中文字幕| 亚洲精品制服丝袜四区| 日韩精品视频免费观看| 13小箩利洗澡无码视频网站免费| 一本色道久久88亚洲精品综合| 久久久青草青青国产亚洲免观| 13一14周岁毛片免费| 一本久久免费视频| 亚洲国产情侣一区二区三区| 狠狠色婷婷狠狠狠亚洲综合| 久久99九九国产免费看小说| 免费在线看污视频| 国产成人亚洲毛片| 亚洲中文字幕无码一去台湾 | 特级做A爰片毛片免费69| 日本道免费精品一区二区| 风间由美在线亚洲一区| 亚洲国产夜色在线观看| 久久久综合亚洲色一区二区三区| 日韩亚洲国产综合久久久| 免费无码精品黄AV电影| 久久久免费精品re6| 大妹子影视剧在线观看全集免费| 亚洲第一综合天堂另类专| 亚洲日韩乱码中文无码蜜桃| 亚洲女初尝黑人巨高清| 亚洲日本韩国在线| 国产免费观看黄AV片|