- 浏览: 180598 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
cmm:
[img][/img][/url][url][/url][ur ...
JSF2.0简介:页面模版化(系列之四) -
parabellum_sky:
飞到大连,
ERROR 1045: Access denied for user: 'root@localhost' (Using password: YES) -
yuanliyin:
更换皮肤很不错!
动态改变RichFaces的皮肤 -
paomo30000:
请问为什么我在输入了http://localhost:8080 ...
在Eclipse 3.5中使用JSF 2.0开发Web应用环境配置及一个简单例子(系列之二) -
marshan:
<dependency> <groupI ...
动态改变RichFaces的皮肤
1. <rich:scrollableDataTable>
1) <rich:scrollableDataTable> 也是一个 dataTable 类的控件。不过,它提供了一些额外的附加功能:
l 当表格滚动时,通过 Ajax 从 Server 取得数据行;
l 可以一次性选中多个行;
l 可以任意调整列的宽度;
l 可以设定冻结列;
l 可以轻易的实现排序;
2) Ajax 滚动数据表格
l 通过 width 和 height 属性定义表格外观尺寸;
l 通过 rows 属性,定义一次性用 Ajax 取回的行数;
l <rich:scrollableDataTable> 需要在 form 里,才能实现 Ajax 取回数据行;
l 另外,根据我的实验,最好把 sortMode 、 rowKeyVar 等属性设置齐全一些,否则有时外观刷新不正常,比如调整列宽时。
3) 调整列宽度
不用做额外的操作,只是调整 column 的 header 宽度就好,在每次 Request 之间,系统会自动记住列宽。
4) 设定冻结列
使用 frozenColCount 属性,可以定义表格最左边多少列会被冻结,在横向滚动的时候,不会运动。
5) 选中多行
l 需要用到 selection 属性和 binding ;
l selection 属性应该指向 managed bean 中的一个实现了 org.richfaces.model.selection.Selection 接口的对象,通常可以直接使用 org.richfaces.model.selection.SimpleSelection 类对象( SimpleSelection 实现了 Selection 接口)。
l binding 应该指向 managed bean 中的 UIScrollableDataTable 对象。
l 基本原理:在 browser 端,用户选定多行数据,通过提交( Ajax 或 Server ), Server 端更新 Selection 的值,再解析 Selection 的值,查看每一个 rowKey 在 table 中是否可用,从而取得 table 对应行中的数据。
l 具体实现:
<rich:scrollableDataTable value="#{dataTableScrollerBean.xcvrList}" var="xcvr" rows="20" height="300px" width="400px" sortMode="single" rowKeyVar="rkv" frozenColCount="1" binding="#{dataTableScrollerBean.table}" selection="#{dataTableScrollerBean.selection}" >
<a4j:support event="onselectionchange " reRender="out1" actionListener="#{dataTableScrollerBean.takeSelection}" ></a4j:support>
<rich:column id="itemCode">
<f:facet name="header">
<h:outputText value="Item Code" />
</f:facet>
<h:outputText value="#{xcvr.itemCode}"></h:outputText>
</rich:column>
……
</rich:scrollableDataTable>
<h:outputText id="out1" value="#{dataTableScrollerBean.selectedXcvrs}">
private UIScrollableDataTable table;
private SimpleSelection selection;
private List<Xcvr> selectedXcvrs = new ArrayList<Xcvr>();
// Getter and Setter for above 3 member variables.
……
public void takeSelection(ActionEvent evt) {
selectedXcvrs.clear();
Iterator<Object> it = selection.getKeys();
while(it.hasNext()) {
table.setRowKey(it.next());
if(table.isRowAvailable() ) {
selectedXcvrs.add((Xcvr)table.getRowData() );
}
}
}
在 JSP 页面里通过 <a4j:support> ,在发生 onselectionchange 事件的时候,发起提交,调用 managed bean 的 actionListener 方法 takeSelection() 。
在 managed bean 的 takeSelection 方法里,首先使用 Selection 的 getKeys 方法,返回一个 Iterator<Object> ;然后遍历,将这个 Iterator<Object> 中的每一个 Key ,通过 UIScrollableDataTable 的 setRowKey 方法设为当前 Key ;如果 UIScrollableDataTable 的 isRowAvailable() 方法为真,即当前行数据可用,则通过 getRowData() 方法加 Casting 操作,获得对应的数据对象。
6) 实现排序
l 设定 sortMode 属性,两种选择: single 或 multy ;
l <rich:column> 的 id 必须与 column 中的数据对象的属性名相对应,即:
<rich:column id="itemCode ">
<f:facet name="header">
<h:outputText value="Item Code" />
</f:facet>
<h:outputText value="#{xcvr.itemCode }"></h:outputText>
</rich:column>
l 如果无法实现对应(如 column 中包含多个属性值的联合),则必须给 <rich:column> 加上 sortBy 属性,如:
<rich:column id="c1" sortBy=”#{xcvr.itemCode}” >
<f:facet name="header">
<h:outputText value="Item Code / Tech" />
</f:facet>
<h:outputText value="#{xcvr.itemCode}, #{xcvr.tech} "></h:outputText>
</rich:column>
2. 关于 dataTable 的 sort 和 filter
我曾在第 7 章,对于数据表的排序、筛选留有疑问。通过上面的排序实现和用户指南,大致有了了解:
1) 在 <rich:dataTable> 中设定好 sortMode ;
2) 在 <rich:column> 中设置好 sortBy 和 filterBy 属性:
<rich:column id="itemCode" sortBy="#{xcvr.itemCode}" filterBy="#{xcvr.itemCode}" >
<f:facet name="header">
<h:outputText value="Item Code"></h:outputText>
</f:facet>
<h:outputText id="out1" value="#{xcvr.itemCode}"></h:outputText>
</rich:column>
3) 用户指南在 <rich:column> 的章节有详细的介绍。
3. <rich:tree>
1) <rich:tree> 控件用来显示具有层级关系的内容。它的 value 属性接受的是 TreeNode ( org.richfaces.model.TreeNode )接口的对象,当然也可以直接使用 TreeNode 的实现类 org.richfaces.model.TreeNodeImpl 。
2) TreeNode 与 TreeNodeImpl 的主要 API 方法:
l public void addChild (java.lang.Object identifier, TreeNode <T > child)
此方法用于为 Node 节点添加子节点,参数 identifier 用于标识符,区分子节点;
l public void setData(T data)
此方法用于设置 Node 节点自身所包含的数据。可以是任意类型的。
3) 通常可以使用递归的方法,生成节点树,比如文件树等。
public void createTree() {
FacesContext context = FacesContext.getCurrentInstance();
ExternalContext externalContext = context.getExternalContext();
File rootDir = new File(((ServletContext) externalContext.getContext()).getRealPath("/"));
root = new TreeNodeImpl<File>();
addNodes(rootDir, root);
}
public void addNodes(File file, TreeNode<File> node) {
int count = 1;
// 为当前节点设置 Data ,即将当前目录设为当前节点的数据内容
node.setData(file);
// 遍历子文件和子目录
for (File childFile : file.listFiles()) {
TreeNodeImpl<File> childNode = new TreeNodeImpl<File>();
if (childFile.isFile()) {
// 如果为单个文件,则作为子节点数据内容
childNode.setData(childFile);
} else {
// 如果为目录,则递归生成子节点树
addNodes(childFile, childNode);
}
// 将子节点或字节点树加入当前节点
node.addChild(count++, childNode);
}
}
4) 将整个节点树的根节点,传入 <rich:tree> 的 value 属性。
<rich:tree value="#{treeTestBean.root}" />
5) <rich:tree> 应置于 form 中使用,并且有三种切换模式 switchType :
l Ajax (默认):通过 Ajax 提交实现,每次展开闭合都会引起 Ajax Request ;
l Server :引起常规提交;
l Client : 所有操作只基于 Client 端 , 与 Server 没有交互。
6) 关于处理选择节点事件:
l ajaxSubmitSelection 属性为 true 的话,选择节点时,提交方式为 Ajax 。
l managed bean 中应该定义一个型为
public void selectionListener(NodeSelectedEvent event) 的方法。
l <rich:tree> 的 nodeSelectListener 属性应该指向这个 Listener 方法。
l 例如:
public void selectionListener(NodeSelectedEvent evt ) throws IOException {
UITree tree = (UITree) evt.getComponent();
File file = (File) tree.getRowData();
nodeTitle = file.getName();
}
通过 NodeSelectedEvent 的 getComponent 方法获得产生该节点选择事件的 Tree 控件(这与 ActionEvent 的 getComponent 方法类似)。通过 UITree 的 getRowData 方法,返回当前节点自身包含的数据内容。
7) 关于处理展开闭合事件:
l managed bean 中应该定义一个型为
public void expansionListener(NodeExpandedEvent evt) 。
l <rich:tree> 的 changeExpandListener 属性应该指向这个 Listener 方法。
l 例如:
<rich:tree value="#{treeTestBean2.root}" nodeSelectListener="#{treeTestBean2.selectionListener}" changeExpandListener="#{treeTestBean2.expansionListener}" ajaxSubmitSelection="true" reRender=”out1” />
8) 可以使用 icon, iconCollapsed, iconExpanded, iconLeaf 属性修改不同节点不同状态下的图标样式。
9) 使用 <rich:treeNode>
l <rich:treeNode> 控件可以为不同类型的节点,提供不同类型的外观;
l 主要用法是: <rich:tree> 具有 nodeFaces 属性,这个属性可以指向 bean 中的某个 property 。可以根据这个 property 的可能取值,在 <rich:treeNode> 中定义不同的外观。不同的 property 取值之间,通过 <rich:treeNode> 的 type 区分。当有一个节点树的时候,系统遍历每个节点,将该节点的数据内容的该 property 值与多个 <rich:treeNode> 的 type 属性值进行比较,匹配上哪个,就使用哪个 <rich:treeNode> 定义的外观。
l 例如:
<rich:tree value="#{treeTestBean2.root}" nodeSelectListener="#{treeTestBean2.selectionListener}" changeExpandListener="#{treeTestBean2.expansionListener}" ajaxSubmitSelection="true" var="file" nodeFace="#{file.directory}" >
<rich:treeNode type="true" >
<h:outputText value="[DIR]#{file.name}" />
</rich:treeNode>
<rich:treeNode type="false" >
<h:outputText value="[FILE]#{file.name}" />
</rich:treeNode>
</rich:tree>
在这个例子中, file 本身是一个 File 对象,具有 isDirectory() 方法用于判断该 File 对象是一个目录还是一个单独文件。我将它作为 bean 的 property 传给 nodeFaces 属性。当得到一个节点时,查看该节点内容( File 对象)的该 property 值,如果值为 true ,则应用第一个 treeNode 的外观;如果为 false ,则用第二个。
l <rich:treeNode> 除了 markup 重定义了以外,其他 <rich:tree> 的属性,它基本都支持。因此也可以为 treeNode 设置用于外观自定义、选择或展开事件处理 Listener 等等方面的属性。
4. <rich:treeNodeAdaptor> 和 <rich:recursiveTreeNodesAdaptor>
大致看了一下,似乎不难,只是非常简单的递归。基本思路就是:
1) 定义一个 MyNode 类,其中包含一个可以返回其子节点数组的 getter 方法,返回类型为 MyNode[] 。例如:
public class MyNode {
private MyNode[] children;
public MyNode[] getChildren() {
……
return children;
}
}
2) 假设 managed bean 中定义一个名为 myRoots 的 MyNode 数组对象,代表多个主节点;
3) 在 <rich:recursiveTreeNodesAdaptor> 中,按如下设置:
<rich:tree style="width:300px" switchType="ajax">
<rich:recursiveTreeNodesAdaptor roots="#{testBean.myRoots}" var="item" nodes="#{item.children}" />
</rich:tree>
1) <rich:scrollableDataTable> 也是一个 dataTable 类的控件。不过,它提供了一些额外的附加功能:
l 当表格滚动时,通过 Ajax 从 Server 取得数据行;
l 可以一次性选中多个行;
l 可以任意调整列的宽度;
l 可以设定冻结列;
l 可以轻易的实现排序;
2) Ajax 滚动数据表格
l 通过 width 和 height 属性定义表格外观尺寸;
l 通过 rows 属性,定义一次性用 Ajax 取回的行数;
l <rich:scrollableDataTable> 需要在 form 里,才能实现 Ajax 取回数据行;
l 另外,根据我的实验,最好把 sortMode 、 rowKeyVar 等属性设置齐全一些,否则有时外观刷新不正常,比如调整列宽时。
3) 调整列宽度
不用做额外的操作,只是调整 column 的 header 宽度就好,在每次 Request 之间,系统会自动记住列宽。
4) 设定冻结列
使用 frozenColCount 属性,可以定义表格最左边多少列会被冻结,在横向滚动的时候,不会运动。
5) 选中多行
l 需要用到 selection 属性和 binding ;
l selection 属性应该指向 managed bean 中的一个实现了 org.richfaces.model.selection.Selection 接口的对象,通常可以直接使用 org.richfaces.model.selection.SimpleSelection 类对象( SimpleSelection 实现了 Selection 接口)。
l binding 应该指向 managed bean 中的 UIScrollableDataTable 对象。
l 基本原理:在 browser 端,用户选定多行数据,通过提交( Ajax 或 Server ), Server 端更新 Selection 的值,再解析 Selection 的值,查看每一个 rowKey 在 table 中是否可用,从而取得 table 对应行中的数据。
l 具体实现:
<rich:scrollableDataTable value="#{dataTableScrollerBean.xcvrList}" var="xcvr" rows="20" height="300px" width="400px" sortMode="single" rowKeyVar="rkv" frozenColCount="1" binding="#{dataTableScrollerBean.table}" selection="#{dataTableScrollerBean.selection}" >
<a4j:support event="onselectionchange " reRender="out1" actionListener="#{dataTableScrollerBean.takeSelection}" ></a4j:support>
<rich:column id="itemCode">
<f:facet name="header">
<h:outputText value="Item Code" />
</f:facet>
<h:outputText value="#{xcvr.itemCode}"></h:outputText>
</rich:column>
……
</rich:scrollableDataTable>
<h:outputText id="out1" value="#{dataTableScrollerBean.selectedXcvrs}">
private UIScrollableDataTable table;
private SimpleSelection selection;
private List<Xcvr> selectedXcvrs = new ArrayList<Xcvr>();
// Getter and Setter for above 3 member variables.
……
public void takeSelection(ActionEvent evt) {
selectedXcvrs.clear();
Iterator<Object> it = selection.getKeys();
while(it.hasNext()) {
table.setRowKey(it.next());
if(table.isRowAvailable() ) {
selectedXcvrs.add((Xcvr)table.getRowData() );
}
}
}
在 JSP 页面里通过 <a4j:support> ,在发生 onselectionchange 事件的时候,发起提交,调用 managed bean 的 actionListener 方法 takeSelection() 。
在 managed bean 的 takeSelection 方法里,首先使用 Selection 的 getKeys 方法,返回一个 Iterator<Object> ;然后遍历,将这个 Iterator<Object> 中的每一个 Key ,通过 UIScrollableDataTable 的 setRowKey 方法设为当前 Key ;如果 UIScrollableDataTable 的 isRowAvailable() 方法为真,即当前行数据可用,则通过 getRowData() 方法加 Casting 操作,获得对应的数据对象。
6) 实现排序
l 设定 sortMode 属性,两种选择: single 或 multy ;
l <rich:column> 的 id 必须与 column 中的数据对象的属性名相对应,即:
<rich:column id="itemCode ">
<f:facet name="header">
<h:outputText value="Item Code" />
</f:facet>
<h:outputText value="#{xcvr.itemCode }"></h:outputText>
</rich:column>
l 如果无法实现对应(如 column 中包含多个属性值的联合),则必须给 <rich:column> 加上 sortBy 属性,如:
<rich:column id="c1" sortBy=”#{xcvr.itemCode}” >
<f:facet name="header">
<h:outputText value="Item Code / Tech" />
</f:facet>
<h:outputText value="#{xcvr.itemCode}, #{xcvr.tech} "></h:outputText>
</rich:column>
2. 关于 dataTable 的 sort 和 filter
我曾在第 7 章,对于数据表的排序、筛选留有疑问。通过上面的排序实现和用户指南,大致有了了解:
1) 在 <rich:dataTable> 中设定好 sortMode ;
2) 在 <rich:column> 中设置好 sortBy 和 filterBy 属性:
<rich:column id="itemCode" sortBy="#{xcvr.itemCode}" filterBy="#{xcvr.itemCode}" >
<f:facet name="header">
<h:outputText value="Item Code"></h:outputText>
</f:facet>
<h:outputText id="out1" value="#{xcvr.itemCode}"></h:outputText>
</rich:column>
3) 用户指南在 <rich:column> 的章节有详细的介绍。
3. <rich:tree>
1) <rich:tree> 控件用来显示具有层级关系的内容。它的 value 属性接受的是 TreeNode ( org.richfaces.model.TreeNode )接口的对象,当然也可以直接使用 TreeNode 的实现类 org.richfaces.model.TreeNodeImpl 。
2) TreeNode 与 TreeNodeImpl 的主要 API 方法:
l public void addChild (java.lang.Object identifier, TreeNode <T > child)
此方法用于为 Node 节点添加子节点,参数 identifier 用于标识符,区分子节点;
l public void setData(T data)
此方法用于设置 Node 节点自身所包含的数据。可以是任意类型的。
3) 通常可以使用递归的方法,生成节点树,比如文件树等。
public void createTree() {
FacesContext context = FacesContext.getCurrentInstance();
ExternalContext externalContext = context.getExternalContext();
File rootDir = new File(((ServletContext) externalContext.getContext()).getRealPath("/"));
root = new TreeNodeImpl<File>();
addNodes(rootDir, root);
}
public void addNodes(File file, TreeNode<File> node) {
int count = 1;
// 为当前节点设置 Data ,即将当前目录设为当前节点的数据内容
node.setData(file);
// 遍历子文件和子目录
for (File childFile : file.listFiles()) {
TreeNodeImpl<File> childNode = new TreeNodeImpl<File>();
if (childFile.isFile()) {
// 如果为单个文件,则作为子节点数据内容
childNode.setData(childFile);
} else {
// 如果为目录,则递归生成子节点树
addNodes(childFile, childNode);
}
// 将子节点或字节点树加入当前节点
node.addChild(count++, childNode);
}
}
4) 将整个节点树的根节点,传入 <rich:tree> 的 value 属性。
<rich:tree value="#{treeTestBean.root}" />
5) <rich:tree> 应置于 form 中使用,并且有三种切换模式 switchType :
l Ajax (默认):通过 Ajax 提交实现,每次展开闭合都会引起 Ajax Request ;
l Server :引起常规提交;
l Client : 所有操作只基于 Client 端 , 与 Server 没有交互。
6) 关于处理选择节点事件:
l ajaxSubmitSelection 属性为 true 的话,选择节点时,提交方式为 Ajax 。
l managed bean 中应该定义一个型为
public void selectionListener(NodeSelectedEvent event) 的方法。
l <rich:tree> 的 nodeSelectListener 属性应该指向这个 Listener 方法。
l 例如:
public void selectionListener(NodeSelectedEvent evt ) throws IOException {
UITree tree = (UITree) evt.getComponent();
File file = (File) tree.getRowData();
nodeTitle = file.getName();
}
通过 NodeSelectedEvent 的 getComponent 方法获得产生该节点选择事件的 Tree 控件(这与 ActionEvent 的 getComponent 方法类似)。通过 UITree 的 getRowData 方法,返回当前节点自身包含的数据内容。
7) 关于处理展开闭合事件:
l managed bean 中应该定义一个型为
public void expansionListener(NodeExpandedEvent evt) 。
l <rich:tree> 的 changeExpandListener 属性应该指向这个 Listener 方法。
l 例如:
<rich:tree value="#{treeTestBean2.root}" nodeSelectListener="#{treeTestBean2.selectionListener}" changeExpandListener="#{treeTestBean2.expansionListener}" ajaxSubmitSelection="true" reRender=”out1” />
8) 可以使用 icon, iconCollapsed, iconExpanded, iconLeaf 属性修改不同节点不同状态下的图标样式。
9) 使用 <rich:treeNode>
l <rich:treeNode> 控件可以为不同类型的节点,提供不同类型的外观;
l 主要用法是: <rich:tree> 具有 nodeFaces 属性,这个属性可以指向 bean 中的某个 property 。可以根据这个 property 的可能取值,在 <rich:treeNode> 中定义不同的外观。不同的 property 取值之间,通过 <rich:treeNode> 的 type 区分。当有一个节点树的时候,系统遍历每个节点,将该节点的数据内容的该 property 值与多个 <rich:treeNode> 的 type 属性值进行比较,匹配上哪个,就使用哪个 <rich:treeNode> 定义的外观。
l 例如:
<rich:tree value="#{treeTestBean2.root}" nodeSelectListener="#{treeTestBean2.selectionListener}" changeExpandListener="#{treeTestBean2.expansionListener}" ajaxSubmitSelection="true" var="file" nodeFace="#{file.directory}" >
<rich:treeNode type="true" >
<h:outputText value="[DIR]#{file.name}" />
</rich:treeNode>
<rich:treeNode type="false" >
<h:outputText value="[FILE]#{file.name}" />
</rich:treeNode>
</rich:tree>
在这个例子中, file 本身是一个 File 对象,具有 isDirectory() 方法用于判断该 File 对象是一个目录还是一个单独文件。我将它作为 bean 的 property 传给 nodeFaces 属性。当得到一个节点时,查看该节点内容( File 对象)的该 property 值,如果值为 true ,则应用第一个 treeNode 的外观;如果为 false ,则用第二个。
l <rich:treeNode> 除了 markup 重定义了以外,其他 <rich:tree> 的属性,它基本都支持。因此也可以为 treeNode 设置用于外观自定义、选择或展开事件处理 Listener 等等方面的属性。
4. <rich:treeNodeAdaptor> 和 <rich:recursiveTreeNodesAdaptor>
大致看了一下,似乎不难,只是非常简单的递归。基本思路就是:
1) 定义一个 MyNode 类,其中包含一个可以返回其子节点数组的 getter 方法,返回类型为 MyNode[] 。例如:
public class MyNode {
private MyNode[] children;
public MyNode[] getChildren() {
……
return children;
}
}
2) 假设 managed bean 中定义一个名为 myRoots 的 MyNode 数组对象,代表多个主节点;
3) 在 <rich:recursiveTreeNodesAdaptor> 中,按如下设置:
<rich:tree style="width:300px" switchType="ajax">
<rich:recursiveTreeNodesAdaptor roots="#{testBean.myRoots}" var="item" nodes="#{item.children}" />
</rich:tree>
发表评论
-
<rich:fileUpload>批量上传
2009-08-10 18:54 1960public class FileUploadBean { ... -
优化JSF Richfaces应用
2009-07-29 21:43 1986使用Richfaces开发基于JSF的RIA应用是非常通用、自 ... -
动态改变RichFaces的皮肤
2009-07-29 02:58 2517给RichFaces设置一个皮肤很简单,只要在web.xml文 ... -
Practical_RichFaces要点Chapter11
2009-07-27 04:03 9071. 使用内建的 Skins 1) 基 ... -
Practical_RichFaces要点Chapter09
2009-07-27 03:59 15031. <rich:dropDownM ... -
Practical_RichFaces要点Chapter08
2009-07-27 03:58 14721. <rich:pickList> ... -
Practical_RichFaces要点Chapter07
2009-07-27 03:57 12741. 常用的 dataTable 类的控件有: ... -
Practical_RichFaces要点Chapter01
2009-07-27 03:53 8751. JSF’s View = UICompone ... -
Practical_RichFaces要点Chapter02
2009-07-27 03:51 9531. 配置 RichFaces 1) ... -
Practical_RichFaces要点Chapter03
2009-07-27 03:50 1153本章主要包括三方面内 ... -
Practical_RichFaces要点Chapter04
2009-07-27 03:48 11681. 用队列控制 Event Traffic ... -
Practical_RichFaces要点Chapter05
2009-07-27 03:46 9451. a4j: 提供了页面级的 Ajax 支持,也 ... -
Practical_RichFaces要点Chapter05 (二)
2009-07-27 03:44 13301. <rich:inplaceInput&g ... -
Practical_RichFaces要点Chapter06
2009-07-27 03:42 15101. <rich:panel> 1) ...
相关推荐
《Java JSF Richfaces在办公自动化系统中的应用详解》 在现代企业信息化建设中,办公自动化系统的开发与应用已经成为提升工作效率、实现管理现代化的关键。本文将深入探讨如何利用Java、JSF(JavaServer Faces)...
### JBoss RichFaces 3.3:增强JSF Web应用程序的强大力量 #### 引言 《JBoss RichFaces 3.3》是一本专为希望利用强大的AJAX组件来增强JSF(JavaServer Faces)Web应用的开发人员而编写的书籍。作者Demetrio ...
dwRichFaces4Demo1 示例应用程序很简单;其惟一的真正目的是展示所选组件的设置和用法。因此,它的作用便是收集和显示输入数据。请想象一下如何在生产应用程序中使用数据和组件。除了必要的 JAR、图像、支持资源绑定...
《Practical RichFaces》这本书深入探讨了如何在JavaServer Faces (JSF) 应用程序中有效地使用RichFaces框架,从而实现高效的AJAX功能。 RichFaces是一个强大的JSF组件库,它极大地扩展了JSF的功能,特别是在提升...
《Practical JBoss Seam》是一本深入探讨JBoss Seam框架技术的书籍,其源代码包含在提供的压缩包中。Seam是一种开源的企业级Java框架,它整合了多种技术和概念,如JavaServer Faces (JSF)、Java Persistence API ...
《Practical RichFaces, 2nd Edition》是一本专注于JavaServer Faces (JSF)及其增强库RichFaces的实用指南。本书旨在帮助开发者深入了解并充分利用JSF和RichFaces的强大功能,特别是在Web应用程序开发领域。随着技术...
《深入理解RichFaces 3.3.1:框架精髓与应用实践》 一、引言 RichFaces 3.3.1是Java Server Faces(JSF)生态系统中的一个强大组件库,它为开发者提供了丰富的UI组件集合以及强大的AJAX支持。此版本的用户手册旨在...
RichFaces_3.3.3_TLD.chm
**标题解析:** "richfaces_helloWorld" 这个标题暗示了我们正在处理一个与RichFaces框架相关的示例项目,具体来说是一个“Hello World”应用。RichFaces是基于JavaServer Faces (JSF) 技术的开源用户界面组件库,...
《深入解析RichFaces 3.3用户指南:框架精髓与实战应用》 一、引言:RichFaces框架概览 RichFaces 3.3作为一款先进的企业级开发框架,为开发者提供了丰富的组件库以及强大的皮肤支持,极大地提升了Web应用程序的...
### RichFaces框架知识点详解 #### 一、简介 RichFaces是一款功能强大的开源JavaScript库与Java Server Faces (JSF) 集成的组件库,它提供了丰富的用户界面组件以及Ajax支持,大大简化了Web应用程序的开发过程。此...
### RichFaces框架详解及其在IT行业的应用 #### 引言 在现代Web开发领域,提升用户体验...掌握RichFaces的核心概念和技术要点,对于任何致力于提升Web开发效率、优化用户体验的开发者来说,都是一项不可或缺的技能。
**Richfaces ShowCase离线包** 是一个专为开发者设计的资源包,它包含了Richfaces框架的演示示例,能够帮助用户在没有网络连接的情况下也能深入理解和学习Richfaces的功能和用法。这个离线包特别适合那些需要在本地...
RichFaces 4.5 是一个强大的JavaServer Faces (JSF) 框架的扩展库,专为构建富互联网应用程序(Rich Internet Applications, RIA)而设计。这个库提供了丰富的组件集,以及对JavaScript(JS)和Java API的支持,使得...
**RichFaces中文开发文档概述** RichFaces是一款基于JavaServer Faces(JSF)技术的开源UI组件库,由JBoss组织开发。它为JSF应用程序提供了丰富的用户体验和强大的交互功能。这款框架极大地简化了Web开发过程,尤其...
《深入理解RichFaces UI 3.2.1在JBoss中的应用》 RichFaces UI 3.2.1是JBoss框架中一个重要的组件,它为开发人员提供了一套强大的AJAX(Asynchronous JavaScript and XML)功能,极大地提升了Web应用程序的交互性和...