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

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

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

    幸せのちから

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

    定制FilterRowsCallback

    定制FilterRowsCallback


    1. 引言

    FilterRowsCallback被用來過濾傳給eXtremeTable的Beans的Collection。 FilterRowsCallback的默認實現是得到Beans或Maps的Collection,然后通過實現jakarta Predicate接口來進行過濾。當然,如果你需要進行一些定制你可以插接自己的實現。

    首先聲明,本示例代碼包含一些從原包中剪切、粘貼的代碼(雖然不是很多)。在 最初的最終發行包之后,值過濾得到進一步改善使得更具復用性并更容易實現,可能和定制cell代碼行數相同。 當然,我被要求并非常樂意示范如何在當前代碼基礎上實現定制過濾。這有非常清晰的hooks實現,并且很容易實現。

    本示例示范了如何調整代碼為過濾器提供一個精確的比較功能。當前的實現是通過使用StringUtils.contains()方法進行模糊比較。 本示例將使用StringUtils.equals()方法。你可以按照你的需要來調整代碼進行更多定制。

    1.1. 定制FilterRowsCallback示例

    首先你需要做的是創建一個實現Predicate接口的定制類。Predicate要求我們實現evaluate()方法來判斷是否包含 當前bean。因為你僅僅調整現在已有的功能,首先得到filterPredicate的源代碼(在發行包的callback包下), 拷貝到你的工程里。然后向下面展示的一樣將 StringUtils.contains()方法修改為StringUtils.equals()方法:

    public final class ExactMatchFilterPredicate implements Predicate {
    private boolean isSearchMatch(String value, String search) {

    ...

    else if (StringUtils.equals(value, search)) {
    return true;
    }

    ...

    }
    }

    然后我們需要實現和Predicate共同作用的FilterRowsCallback接口。再一次從發行包的callback包下拷貝ProcessRowsCallback源代碼到你的工程里。 請參照我們創建的定制的ExactMatchFilterPredicate 類來確認僅僅實現了FilterRowsCallback和修改Predicate。

    public class ExactMatchFilterRows implements FilterRowsCallback {
    public Collection filterRows(TableModel model, Collection rows) throws Exception {

    ...

    if (filtered) {
    Collection collection = new ArrayList();
    Predicate filterPredicate = new ExactMatchFilterPredicate(model);
    CollectionUtils.select(rows, filterPredicate, collection);

    return collection;
    }

    ...

    }
    }

    為了使用這個FilterRowsCallback你應該在Preferences中聲明一個別名。當然,你可以省略這步而在JSP中提供這個FilterRowsCallback實現類的全路徑,但是使用Preferences更簡潔。

    table.filterRowsCallback.exactMatch=org.extremesite.callback.ExactMatchFilterRows

    在TableTag通過設置filterRowsCallback屬性來使用ExactMatchFilterRows。

    <ec:table filterRowsCallback="exactMatch"/>

    如果不清楚Preferences和ColumnTag定義語法請參考Preferences指南。

    posted on 2006-02-24 10:29 Lucky 閱讀(568) 評論(0)  編輯  收藏 所屬分類: extremeComponents

    <2006年2月>
    2930311234
    567891011
    12131415161718
    19202122232425
    2627281234
    567891011

    導航

    隨筆分類(125)

    文章分類(5)

    日本語

    搜索

    積分與排名

    最新隨筆

    最新評論

    主站蜘蛛池模板: 国产成人亚洲综合无| 亚洲免费观看网站| 日韩精品无码永久免费网站| 男女做羞羞的事视频免费观看无遮挡| 亚洲国产精品热久久| 暖暖免费日本在线中文| 亚洲国产精品久久久久婷婷软件| 十九岁在线观看免费完整版电影| 亚洲国产精品不卡在线电影| 未满十八18禁止免费无码网站| 亚洲av永久无码精品漫画| 69视频在线观看免费| 亚洲电影在线播放| 香蕉97超级碰碰碰免费公| 亚洲综合色一区二区三区| 国产精品色午夜免费视频| 全黄A免费一级毛片| 亚洲色偷偷综合亚洲AVYP| 国产免费爽爽视频在线观看| 亚洲综合久久成人69| 免费影院未满十八勿进网站| 亚洲а∨精品天堂在线| 久久综合亚洲色HEZYO国产| 免费视频一区二区| 亚洲一线产区二线产区精华| 日本无卡码免费一区二区三区| 色偷偷尼玛图亚洲综合| 亚洲综合在线另类色区奇米| 99免费观看视频| 欧美亚洲国产SUV| 亚洲综合色在线观看亚洲| 鲁大师在线影院免费观看| 中国亚洲呦女专区| 久久亚洲av无码精品浪潮| 外国成人网在线观看免费视频| 亚洲综合精品伊人久久| 亚洲天堂免费在线视频| 色片在线免费观看| 一级特黄a免费大片| 亚洲日韩乱码久久久久久| 亚洲精品无码专区久久同性男|