Table 组件使用指南:获取选中的Rows
来源:互联网 发布:cba周琦数据统计 编辑:程序博客网 时间:2024/06/06 08:43
开发环境:JDeveloper 11.1.2.2.0 + Oracle XE Database 10gR2。
重点步骤说明:
1. 创建一个新页面:table_selected_rows.jsf
(1)设置RowSelection=mutiple,允许多选。
(2)设置Binding,指向Managed Bean中的一个属性。
(3)放置一个按钮,点击按钮,调用Managed Bean中的方法,获取选中的Table行。
2. 完整的Managed Bean代码
可以看出获取Table的选中行和获取Tree的选中节点的代码(参考《获取选中的Tree节点》)几乎完全一致。
3. 运行效果,按住Ctrl键多选几个节点,然后点击按钮
输出如下:
########################### JobId:SA_MAN
########################### JobTitle:Sales Manager
########################### MinSalary:10000
########################### MaxSalary:20000
########################### row ViewRow [oracle.jbo.Key[SA_MAN ]]
########################### rowType JobsView
########################### nodeStuctureDefname model.JobsView
########################### JobId:PU_MAN
########################### JobTitle:Purchasing Manager
########################### MinSalary:8000
########################### MaxSalary:15000
########################### row ViewRow [oracle.jbo.Key[PU_MAN ]]
########################### rowType JobsView
########################### nodeStuctureDefname model.JobsView
########################### JobId:FI_ACCOUNT
########################### JobTitle:Accountant
########################### MinSalary:4200
########################### MaxSalary:9000
########################### row ViewRow [oracle.jbo.Key[FI_ACCOUNT ]]
########################### rowType JobsView
########################### nodeStuctureDefname model.JobsView
重点步骤说明:
1. 创建一个新页面:table_selected_rows.jsf
(1)设置RowSelection=mutiple,允许多选。
(2)设置Binding,指向Managed Bean中的一个属性。
(3)放置一个按钮,点击按钮,调用Managed Bean中的方法,获取选中的Table行。
2. 完整的Managed Bean代码
package view;import java.util.Iterator;import java.util.List;import javax.faces.event.ActionEvent;import oracle.adf.view.rich.component.rich.data.RichTable;import oracle.jbo.Row;import oracle.jbo.uicli.binding.JUCtrlHierNodeBinding;import oracle.jbo.uicli.binding.JUCtrlHierBinding;import oracle.jbo.uicli.binding.JUCtrlHierTypeBinding;import org.apache.myfaces.trinidad.model.CollectionModel;import org.apache.myfaces.trinidad.model.RowKeySet;public class MyBackingBean { private RichTable table; public MyBackingBean() { } public void printButton_ActionListener(ActionEvent evt) { RichTable table = this.getTable(); RowKeySet rks = table.getSelectedRowKeys(); Iterator rksIterator = rks.iterator(); while (rksIterator.hasNext()) { List key = (List)rksIterator.next(); JUCtrlHierBinding tableBinding = null; CollectionModel collectionModel = (CollectionModel)table.getValue(); collectionModel.setRowKey(key); tableBinding = (JUCtrlHierBinding)collectionModel.getWrappedData(); JUCtrlHierNodeBinding nodeBinding = tableBinding.findNodeByKeyPath(key); String[] strs = nodeBinding.getAttributeNames(); for (String str : strs) { System.out.println("########################### " + str + ":" + nodeBinding.getAttribute(str)); } Row rw = nodeBinding.getRow(); System.out.println("########################### row " + rw); String rowType = rw.getStructureDef().getDefName(); System.out.println("########################### rowType " + rowType); JUCtrlHierTypeBinding typeBinding = nodeBinding.getHierTypeBinding(); String nodeStuctureDefname = typeBinding.getStructureDefName(); System.out.println("########################### nodeStuctureDefname " + nodeStuctureDefname); } } public void setTable(RichTable table) { this.table = table; } public RichTable getTable() { return table; }}
可以看出获取Table的选中行和获取Tree的选中节点的代码(参考《获取选中的Tree节点》)几乎完全一致。
3. 运行效果,按住Ctrl键多选几个节点,然后点击按钮
输出如下:
########################### JobId:SA_MAN
########################### JobTitle:Sales Manager
########################### MinSalary:10000
########################### MaxSalary:20000
########################### row ViewRow [oracle.jbo.Key[SA_MAN ]]
########################### rowType JobsView
########################### nodeStuctureDefname model.JobsView
########################### JobId:PU_MAN
########################### JobTitle:Purchasing Manager
########################### MinSalary:8000
########################### MaxSalary:15000
########################### row ViewRow [oracle.jbo.Key[PU_MAN ]]
########################### rowType JobsView
########################### nodeStuctureDefname model.JobsView
########################### JobId:FI_ACCOUNT
########################### JobTitle:Accountant
########################### MinSalary:4200
########################### MaxSalary:9000
########################### row ViewRow [oracle.jbo.Key[FI_ACCOUNT ]]
########################### rowType JobsView
########################### nodeStuctureDefname model.JobsView
- Table 组件使用指南:获取选中的Rows
- Table 组件使用指南之七:获取选中的Rows
- Tree组件使用指南之十:获取选中的Tree节点
- Table 组件使用指南:基于Table的CRUD
- js获取table的行/列:table.rows[].cells[]
- Table 组件使用指南之二:基于Table的CRUD
- 关于获取table选中行的随笔
- bootstrap table获取选中行的值
- bootstrap-table 获取选中的行
- Table 组件使用指南:定制SelectionListener
- Table 组件使用指南:使用Poll组件刷新Table
- Table 组件使用指南之五:使用Poll组件刷新Table
- Table 组件使用指南:增加Column Footer Sum
- Table 组件使用指南:列字段过滤功能
- Table 组件使用指南:动态增加Column
- Table 组件使用指南:设置宽度和高度
- Table 组件使用指南:修改默认排序规则
- Table 组件使用指南之一:浏览与修改
- 关于图的一个小递归
- InstallShield 修改版权信息 修改产品描述
- 数据库范式(1NF 2NF 3NF BCNF)详解一
- .bash_profile、.bashrc、和.bash_logout
- 解决WebService测试窗体只能用于来自本地计算机的请求 .
- Table 组件使用指南:获取选中的Rows
- Flashback Query 还原数据
- 打包ios程序成ipa
- air native extension java代码在ane文件解压后
- mysql插入性能改善
- js截取中英文字符串无乱码
- 记一点小东西
- ValueStack 理解
- merge用法