新聞中心
周二,我興匆匆去老劉那演示RichFaces的Table控件,可老劉說(shuō)了,RichFaces太復(fù)雜,不適合我們,且還有不少的bug(這些我無(wú)法考證:)。于是他拿出一個(gè)使用了一堆JSP+Servelet+Bean寫(xiě)的一個(gè)表格,跟說(shuō)我,我很懷疑JSF能做出這個(gè)東西來(lái),你使用純JSF做一個(gè)一樣的表格組件我就相信JSF能夠用在開(kāi)發(fā)平臺(tái)(注:我是此Eclipse開(kāi)發(fā)平臺(tái)的兼職架構(gòu)師)上。我心里琢磨,既然你是用JSP/Servlet搞出來(lái)的,而JSF是基于Servlet的技術(shù),怎么可能實(shí)現(xiàn)不了呢? 三天做出來(lái)!我一直相信,技術(shù)在于使用技術(shù)的人,而不是技術(shù)本身。

下載JSF表格組件
先看圖吧:
再看看對(duì)應(yīng)的JSF標(biāo)記
- < !DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
- < html xmlns="http://www.w3.org/1999/xhtml"
- xmlns:h="http://java.sun.com/jsf/html"
- xmlns:f="http://java.sun.com/jsf/core"
- xmlns:ui="http://java.sun.com/jsf/facelets"
- xmlns:cby="http:/www.lifesting.com/jsf">
- < ui:composition template="/tpl.xhtml">
- < ui:define name="pageTitle">表格展示< /ui:define>
- < ui:define name="pageHeader">國(guó)家< /ui:define>
- < ui:define name="body">
- < h:form>
- < h:panelGrid columns="1">
- < h:message for="mytable" />
- < /h:panelGrid>
- < cby:rns text="頁(yè)面設(shè)置" tableFor="mytable" />
- < cby:filter text="過(guò)濾策略" tableFor="mytable" />
- < cby:delete tableFor="mytable" />
- < cby:table id="mytable" var="rec" checkable="true" idField="code"
- bean="Country">
- < cby:column field="name" sortable="true" filterable="true"
- width="200" value="名稱(chēng)">
- < h:outputText value="#{rec.wrapped.name}">< /h:outputText>
- < /cby:column>
- < cby:column field="region" sortable="true" filterable="false"
- width="100" value="區(qū)域">
- < h:outputText value="#{rec.wrapped.region}">< /h:outputText>
- < /cby:column>
- < cby:column field="surfaceArea" sortable="false" filterable="true"
- width="150" value="表面積">
- < h:outputText value="#{rec.wrapped.surfaceArea}">< /h:outputText>
- < /cby:column>
- < cby:column field="population" sortable="true" filterable="true"
- width="100" value="人口">
- < h:outputText value="#{rec.wrapped.population}">< /h:outputText>
- < /cby:column>
- < cby:ds />
- < /cby:table>
- < /h:form>
- < /ui:define>
- < /ui:composition>
- < /html>
因?yàn)殚_(kāi)發(fā)平臺(tái)最終是以BO為核心,所以此表格組件是通過(guò)設(shè)置 bean,然后再通過(guò)Hibernate來(lái)獲取數(shù)據(jù)的。
這個(gè)JSF表格組件除采用JSF +Facelet之外,沒(méi)有其它頁(yè)面技術(shù),代碼簡(jiǎn)潔,無(wú)抽象,且里面還有注釋?zhuān)鯇W(xué)者可以參考一下。
JSF表格組件主要功能:
1 設(shè)置column的filterable屬性(true/false)來(lái)過(guò)濾數(shù)據(jù)(目前實(shí)現(xiàn)為左匹配,比如輸入Sa,就是Sa開(kāi)頭的)
2 分頁(yè)導(dǎo)航
3 設(shè)置column的sortable屬性(true/false)用來(lái)對(duì)某列進(jìn)行 正/反 排序
4 改變頁(yè)記錄大小,默認(rèn)為20條/頁(yè)
5 設(shè)置table的checkable屬性為true,表格將會(huì)多一列用來(lái)選擇。
6 可以批量刪除被checked的記錄。
這個(gè)組件只考慮了功能,并沒(méi)有考慮到美觀,如果你覺(jué)得可以用,改改它的html屬性設(shè)置。
安裝:
1 附件是一個(gè)Maven項(xiàng)目,必須安裝有maven。
2 安裝MySQL數(shù)據(jù)庫(kù),啟動(dòng)MySQL,運(yùn)行
create database world
3 找到項(xiàng)目下面的world.sql,假設(shè)其路徑為/a/b/c/world.sql,使用MySQL的source命令
use world
source /a/b/c/world.sql
4修改項(xiàng)目下的hibernate.cfg.xml中MySQL數(shù)據(jù)庫(kù)用戶(hù)名/密碼。
5 執(zhí)行mvn jetty:run 啟動(dòng)
6 瀏覽器輸入 http://localhost:8080/jsftry/ 就可以看到效果了
關(guān)于調(diào)試:
1 下載一個(gè)Eclipse JEE版本
2 在項(xiàng)目目錄下執(zhí)行 mvn eclipse:clean eclipse:eclipse -DdownloadSources=true -Dwtpversion=1.5
3 在eclipse workspace中import此項(xiàng)目
雖然工作中不用Java很久了,但拿起來(lái)玩玩還是覺(jué)得Java真的很有生產(chǎn)力。JSF,Hibernate,Maven,Eclipse一個(gè)比一個(gè)牛比。
分享標(biāo)題:JSF表格組件的制作思路(含源代碼)
URL地址:http://www.5511xx.com/article/dpepgie.html


咨詢(xún)
建站咨詢(xún)
