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

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

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

    像一顆晨土

    常用鏈接

    統計

    blogs

    life

    最新評論

    收藏一篇extremeComponents使用AJAX 指南

    extremeComponents使用AJAX 指南
    Mon, 27 Mar 2006 08:09:00 GMT

    AJAX 指南

    進行中...


    在eXtremeTable中使用AJAX非常簡單,對現有功能的擴展也非常方便。 AJAX整合一個最強大的地方是它不需要整合。你可以自由地使用任何你想要使用的AJAX工具包。所有你要做的就是:當表的action被調用時,告訴 eXtremeTable使用什么javascript。表的actions包括:過濾、排序、分頁、顯示的行數和導出。

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

    Assembler Example

    本示例中將需要安裝DWR工具包,創建POJO來構造表并創建包含eXtremeTable的JSP頁面。

    安裝DWR

    首先要做的就是下載DWR工具包。你應該瀏覽網站的使用說明,不過下面是我讓它符合我的需要來工作所進行的操作:

    • 將dwr-1.1.jar拷貝到WEB-INF/lib目錄
    • 在WEB-INF目錄下創建一個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>

    簡而言之(In a nutshell)創建(create)標簽允許當方法被調用時,參照構建表需要的POJO。簽名(signature)標簽聲明了被調用方法使用的實際 類型。 本示例的Assembler類的getTable方法將通過傳入一個Map(包含form參數)和HttpServletRequest。

    • 在WEB-INF/web.xml中對DWR servlet進行聲明
      <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的設置,它被用來調用你的POJO。除了設置它,你不需要對這個servlet有更多的了解。

    創建POJO

    DWR使用(works with)POJOs。這個非常符合我們的需要,因為eXtremeTable有足夠的API使用Jsp標簽來構造表。實際上,JSP標簽只不過是eXtremeTable Java API的前端。首先,我將展示構造表的方法:

    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();
    }
    }

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

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

    Assembler類的另一個方法---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 "";
    }
    }

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

    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在被第一次調用時來構建表。它調用POJO并將表傳給request。注意空值(null)如何使用parameterMap傳輸。這是因為第一次表被構造時,沒有對應表需要知道的actions。

    JSP

    通過引入(importing)合適的javascript文件來開始構建JSP頁面。唯一需要包含進工程的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)來顯示表,div被用來調用innerHtml并構建新的標簽。

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

    最后,添加javascript來調用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參數。你需要傳入一個 form id的參照。記住,eXtremeTable本質上是一個form組建,tableid作為form id使用。默認的tableId為ec,但是你通常想要設置tableId,以示大家能更容易閱讀你的代碼。你將使用parameterMap調用 POJO的getTable方法。showTable是一個callback告訴DWR當從getTable()方法返回時將調用什么操作。

    結論

    本指南描述了在eXtremeTable中使用AJAX所需要的步驟。需要留心的一個主要事情是沒有和AJAX發生實際整合。當表的actions 被使用是,你只需要簡單地告訴eXtremeTable什么javascript將被調yong。另一個事情是,通過本示例我們可以知道DWR工具包使用 POJOs并能夠簡單地被任何框架使用。



    posted on 2006-03-30 18:43 艾塵 閱讀(784) 評論(2)  編輯  收藏 所屬分類: learn more

    評論

    # re: 收藏一篇extremeComponents使用AJAX 指南 2009-03-19 17:02 訴訟

    天下文章一大抄,所有這個所謂的指南 都她媽的沒有例子  回復  更多評論   

    # re: 收藏一篇extremeComponents使用AJAX 指南[未登錄] 2009-03-19 17:43 jeff

    樓上的沒看清楚這是收藏嗎?無理取鬧。無語。  回復  更多評論   

    主站蜘蛛池模板: 国产免费久久精品久久久| 成人免费在线看片| 亚洲成?v人片天堂网无码| 亚洲AV综合永久无码精品天堂| 无人在线观看完整免费版视频| 亚洲永久中文字幕在线| 无人在线直播免费观看| 四虎必出精品亚洲高清| 日本免费网站观看| 特级毛片A级毛片100免费播放| 无码欧精品亚洲日韩一区夜夜嗨| 国产AV无码专区亚洲AV琪琪| 亚洲?V无码成人精品区日韩| 99麻豆久久久国产精品免费| 亚洲国产精品嫩草影院在线观看 | 精品国产日韩亚洲一区| 中国人免费观看高清在线观看二区| 国产精品亚洲mnbav网站| a级毛片免费高清毛片视频| 久久久亚洲欧洲日产国码农村| 美丽的姑娘免费观看在线播放| 亚洲中文字幕无码一去台湾| 亚洲&#228;v永久无码精品天堂久久 | 免费视频成人国产精品网站| 亚洲熟伦熟女新五十路熟妇| 久久久久久久99精品免费| 亚洲区视频在线观看| 免费jlzzjlzz在线播放视频| 中文字幕在线成人免费看| 亚洲精品午夜久久久伊人| 国产精品四虎在线观看免费 | 99久久精品免费精品国产| 亚洲精品人成网在线播放影院| 国产区卡一卡二卡三乱码免费| 中国在线观看免费的www| 亚洲乱码一区av春药高潮| 亚洲成av人片天堂网老年人| 精品国产污污免费网站aⅴ| 国产精品亚洲а∨无码播放麻豆 | 日本亚洲色大成网站www久久| 亚洲av午夜精品一区二区三区|