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

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

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

    幸せのちから

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

    Chapter 15. 1.0.1-M4升級說明(1)

    Chapter 15. 1.0.1-M4升級說明

    15.1. 變更概述

    下面的特性已經被更改:

    • HtmlView基于原來代碼的實現已經deprecated

    • Cell接口更簡單

    • 增加RowTag

    • AutoGenerateColumns變為singleton,更易添加列屬性

    • Extended Attributes方法名變更

    • TableTag的collection屬性被刪除

    • BaseModel更名為TableModel

    • Properties和ResourceBundle現在為Preferences和Messages

    • pageContext被Context接口代替

    • Limit和LimitFactory的語法變更,更易于使用

    • TableTag的saveFilterSort屬性被state屬性代替

    • ColumnTag的showTotal屬性被calc屬性代替

    • search圖片的名稱變為filter

    • FormTag/InputTag為deprecated

    • RetrieveRowsCallbacks、FilterRowsCallback、SortRowsCallback都變為singletons

    15.1.1. HtmlView

    我把和舊的view相關的代碼:原始的view、cell和相關代碼放到deprecated文件夾。 原因是新的view代碼非常成功,所以沒有必要使用舊的代碼。使用新代碼構建定制view請參考 view包中的HtmlView或CompactView。

    15.1.2. Cell

    Cell接口已經改變,原因是想結束混亂以提高靈活性。以前對于如何處理區分html和export顯示值 不是十分明顯?,F在Column值設置html,Column的propertyValue設置export。另外因為Column值和 propertyValue值被重寫。現在他們在view中是不可見的。

    cell現在是singleton并且不再線程安全,因此不要定義任何類變量。改變的原因是為 了Cell接口能更簡單地被使用。init()和destroy()方法作為singleton更靈活但是處于一種混亂的狀態。

    Cell接口如下:

    public interface Cell {

    /**
    * The display that will be used for the exports.
    */
    public String getExportDisplay(TableModel model, Column column);

    /**
    * The html that will be displayed in the table.
    */
    public String getHtmlDisplay(TableModel model, Column column);
    }

    現在得到導出和html顯示存在明顯的區別。更重要的,需要返回字符串。列值和屬性值不再 需要設置。另一個細微的區別是:BaseModel已經被TableModel取代。這種改變是的不再需要一個 基礎包(base package),這意味著不再需要BaseModel。

    cell變為singleton不會導致使用復雜,如果你定義了任何類變量只需要把他們放到正確的 方法那么他們就能被任何其他方法使用。

    BaseCell被刪除因為不再需要添加任何值。替代的是AbstractCell,虛擬方法 getCellValue被用來返回cell的值。這種方法非常容易使用并不需要關心markup。查看 AbstractCell也是有意義的,你會發現這代碼實現的多么簡單。然而,很多時候需要做的僅僅是 實現Cell接口:

    DisplayCell:

    public class DisplayCell extends AbstractCell {
    public String getExportDisplay(TableModel model, Column column) {
    return column.getPropertyValueAsString();
    }

    protected String getCellValue(TableModel model, Column column) {
    return column.getValueAsString();
    }
    }

    AbstractCell:

    public abstract class AbstractCell implements Cell {
    public String getExportDisplay(TableModel model, Column column) {
    return getCellValue(model, column);
    }

    public String getHtmlDisplay(TableModel model, Column column) {
    HtmlBuilder html = new HtmlBuilder();
    CellBuilder.tdStart(html, column);
    CellBuilder.tdBody(html, getCellValue(model, column));
    CellBuilder.tdEnd(html);
    return html.toString();
    }

    /**
    * A convenience method to get the display value.
    */
    protected abstract String getCellValue(TableModel model, Column column);
    }

    15.1.3. RowTag

    RowTag<ec:row> 現在被需要,它被用來替代columns。 現在看來它一直被需要。它不知道表中到底有多少列,最近重構的時候我通過 Table -> Row -> Column使結構固定來合并得到更好的靈活性。將來我可能提供更多的 特性,因為我知道eXtremeTable有著清晰的架構。

    典型的eXtremeTable如下:

    <ec:table
    items="presidents"
    var="pres"
    action="${pageContext.request.contextPath}/presidents.run"
    >
    <ec:row>
    <ec:column property="name"/>
    <ec:column property="term"/>
    </ec:row>
    </ec:table>

    15.1.4. AutoGenerateColumns

    AutoGenerateColumns得到了很大的提高,現在你只需要設置你需要的屬性。 當你添加列到ColumnHandler使,defaults將別自動調用。

    AutoGenerateColumns為singleton并且不是線程安全的,因此不要定義任何類變量。

    現在它的實現可能如下:

    public class AutoGenerateColumnsImpl implements AutoGenerateColumns {
    public void addColumns(TableModel model) {
    Iterator iterator = columnsToAdd().iterator();
    while (iterator.hasNext()) {
    Map columnToAdd = (Map) iterator.next();
    Column column = new Column(model);
    column.setProperty((String) columnToAdd.get(PROPERTY));
    column.setCell((String) columnToAdd.get(CELL));
    model.getColumnHandler().addAutoGenerateColumn(column);
    }
    }
    }

    15.1.5. Extended Attributes

    addExtendedAttributes方法重命名使得如何使用這個特性更清晰。 因此RowTag的addExtendedAttributes現在變為addRowAttributes,ColumnTag變 為addColumnAttributes,TableTag變為addTableAttributes,ExportTag變 為addExportAttributes。另外你參考正確的model bean(它的實現更清晰), 將知道如何添加屬性到你的cell、view.....

    使用ExportCsvTag的示例如下:

    public void addExportAttributes(Export export) {
    String view = export.getView();
    if (StringUtils.isBlank(view)) {
    export.setView(TableConstants.CSV);
    export.setImageName(TableConstants.CSV);
    }
    export.addAttribute(CsvView.DELIMITER, getDelimiter());
    }

    為了得到delimiter屬性值你只需要從Export bean中get它:

    Export export = model.getExportHandler().getCurrentExport();
    String delimiter = export.getAttributeAsString(DELIMITER);

    現在你需要在ExportTag中覆蓋它,你只需要調用setter方法。如果是新的屬性,那么使用 可以和前一版一樣使用addAttribute()方法。為了得到值,首先從ExportHandler得到Export, 然后調用需要的getter方法。這和使用其它tags一樣。

    在RowTag和ColumnTag中增加了兩個新的callback方法:modifyRowAttributes和 modifyColumnAttributes,因此你可以在rows/columns被處理時改變屬性值。

    posted on 2006-03-02 13:14 Lucky 閱讀(611) 評論(0)  編輯  收藏 所屬分類: extremeComponents

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

    導航

    隨筆分類(125)

    文章分類(5)

    日本語

    搜索

    積分與排名

    最新隨筆

    最新評論

    主站蜘蛛池模板: 国产乱子伦片免费观看中字| 97人妻无码一区二区精品免费| 永久免费av无码网站大全| 亚洲无人区视频大全| 日韩在线播放全免费| 久久狠狠爱亚洲综合影院| 91在线视频免费91| 自拍日韩亚洲一区在线| 成人性生交大片免费看无遮挡 | 亚洲砖码砖专无区2023| 在线看片免费不卡人成视频| 亚洲午夜成人精品无码色欲| 免费无码成人AV片在线在线播放| 亚洲午夜精品久久久久久app | 免费毛片在线看不用播放器 | 亚洲视频在线观看网站| 亚洲成人免费电影| jlzzjlzz亚洲jzjzjz| 色视频色露露永久免费观看| 精品免费AV一区二区三区| 伊人久久亚洲综合| 久久国产高潮流白浆免费观看| 亚洲中文字幕久在线| 成人爱做日本视频免费| a级毛片免费观看在线| 亚洲精品视频在线观看视频| 最新猫咪www免费人成| 成在线人直播免费视频| 亚洲欧洲一区二区| 在线免费观看污网站| 亚洲天堂免费在线视频| 18亚洲男同志videos网站| 国产美女做a免费视频软件| 中文在线观看永久免费| 久久精品国产99国产精品亚洲 | 亚洲精品免费视频| 四虎永久在线精品免费网址| 一区在线免费观看| 亚洲国产日韩在线一区| 激情综合色五月丁香六月亚洲| 日本最新免费网站|