自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

JSF表格組件的制作思路(含源代碼)

開發(fā) 后端
本博文的作者用JSF做了一個類似于RichFaces的Table控件,并講述了自己制作這個JSF表格組件的思路和感想。

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

下載JSF表格組件

先看圖吧:

JSF表格組件 

再看看對應(yīng)的JSF標記

  1. < !DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
  2. < html xmlns="http://www.w3.org/1999/xhtml" 
  3.     xmlns:h="http://java.sun.com/jsf/html" 
  4.     xmlns:f="http://java.sun.com/jsf/core" 
  5.     xmlns:ui="http://java.sun.com/jsf/facelets" 
  6.     xmlns:cby="http:/www.lifesting.com/jsf"> 
  7.  
  8. < ui:composition template="/tpl.xhtml"> 
  9.  
  10.     < ui:define name="pageTitle">表格展示< /ui:define> 
  11.     < ui:define name="pageHeader">國家< /ui:define> 
  12.     < ui:define name="body"> 
  13.  
  14.     < h:form> 
  15.             < h:panelGrid columns="1"> 
  16.                 < h:message for="mytable" /> 
  17.             < /h:panelGrid> 
  18.             < cby:rns text="頁面設(shè)置" tableFor="mytable" /> 
  19.             < cby:filter text="過濾策略" tableFor="mytable" /> 
  20.             < cby:delete tableFor="mytable" /> 
  21.             < cby:table id="mytable" var="rec" checkable="true" idField="code" 
  22.                 bean="Country"> 
  23.                 < cby:column field="name" sortable="true" filterable="true" 
  24.                     width="200" value="名稱"> 
  25.                     < h:outputText value="#{rec.wrapped.name}">< /h:outputText> 
  26.                 < /cby:column> 
  27.                 < cby:column field="region" sortable="true" filterable="false" 
  28.                     width="100" value="區(qū)域"> 
  29.                     < h:outputText value="#{rec.wrapped.region}">< /h:outputText> 
  30.                 < /cby:column> 
  31.                 < cby:column field="surfaceArea" sortable="false" filterable="true" 
  32.                     width="150" value="表面積"> 
  33.                     < h:outputText value="#{rec.wrapped.surfaceArea}">< /h:outputText> 
  34.                 < /cby:column> 
  35.                 < cby:column field="population" sortable="true" filterable="true" 
  36.                     width="100" value="人口"> 
  37.                     < h:outputText value="#{rec.wrapped.population}">< /h:outputText> 
  38.                 < /cby:column> 
  39.                 < cby:ds /> 
  40.             < /cby:table> 
  41.         < /h:form> 
  42.     < /ui:define> 
  43. < /ui:composition> 
  44.  
  45. < /html> 

因為開發(fā)平臺最終是以BO為核心,所以此表格組件是通過設(shè)置 bean,然后再通過Hibernate來獲取數(shù)據(jù)的。

這個JSF表格組件除采用JSF +Facelet之外,沒有其它頁面技術(shù),代碼簡潔,無抽象,且里面還有注釋,初學者可以參考一下。

JSF表格組件主要功能:
1 設(shè)置column的filterable屬性(true/false)來過濾數(shù)據(jù)(目前實現(xiàn)為左匹配,比如輸入Sa,就是Sa開頭的)
2 分頁導(dǎo)航
3 設(shè)置column的sortable屬性(true/false)用來對某列進行 正/反 排序
4 改變頁記錄大小,默認為20條/頁
5 設(shè)置table的checkable屬性為true,表格將會多一列用來選擇。
6 可以批量刪除被checked的記錄。

這個組件只考慮了功能,并沒有考慮到美觀,如果你覺得可以用,改改它的html屬性設(shè)置。

安裝:

1 附件是一個Maven項目,必須安裝有maven。
2 安裝MySQL數(shù)據(jù)庫,啟動MySQL,運行
create database world
3 找到項目下面的world.sql,假設(shè)其路徑為/a/b/c/world.sql,使用MySQL的source命令
use world
source /a/b/c/world.sql
4修改項目下的hibernate.cfg.xml中MySQL數(shù)據(jù)庫用戶名/密碼。
5 執(zhí)行mvn jetty:run 啟動
6 瀏覽器輸入 http://localhost:8080/jsftry/ 就可以看到效果了

關(guān)于調(diào)試:
1 下載一個Eclipse JEE版本
2  在項目目錄下執(zhí)行 mvn eclipse:clean eclipse:eclipse -DdownloadSources=true -Dwtpversion=1.5
3 在eclipse workspace中import此項目

雖然工作中不用Java很久了,但拿起來玩玩還是覺得Java真的很有生產(chǎn)力。JSF,Hibernate,Maven,Eclipse一個比一個牛比。

【編輯推薦】

  1. JSP換行問題解決辦法一覽
  2. JSP開發(fā)框架JSF對比基于Servlet的Tapestry
  3. JSP像烏云般擋住了JSF的光芒
  4. JSF技術(shù)詳細介紹
  5. 學習JSP的基礎(chǔ)概念之九個隱含對象
責任編輯:yangsai 來源: BlogJava
相關(guān)推薦

2009-06-25 13:03:48

JSF的UI組件

2009-06-29 13:22:19

JSF技術(shù)JSF組件

2009-06-22 13:27:01

JSF組件模型

2009-06-24 13:06:41

JSF組件Facelets

2009-06-24 14:59:00

圖形bean組件JSF圖形組件

2014-06-19 13:47:55

PongoJavaScript

2009-06-22 13:41:58

FaceletsJSF組件

2009-06-24 17:05:10

2009-06-11 11:22:40

JSFJSPJSF的UI組件

2009-06-24 16:30:21

JSF組件模型

2023-12-08 09:15:53

Java單表樹形結(jié)構(gòu)Tree

2009-06-24 15:13:36

自定義JSF組件

2009-06-25 14:53:35

自定義UI組件JSF框架

2009-06-25 11:11:25

控制JSF切入點

2010-06-09 09:15:58

JSF 2Ajax組件

2023-11-23 08:07:31

Css?Web?

2009-04-03 08:28:39

2022-03-09 12:45:15

時間線

2010-09-10 13:24:21

DIV表格

2009-06-22 15:07:45

原則和技巧JSF自定義復(fù)合組件
點贊
收藏

51CTO技術(shù)棧公眾號