我采用的解决方案是使用 setter 和 getter 创建自定义表的对象,将每个字段创建为对象中的属性,即
public class ClaimTableProperties {
private String zuonr;
private String bktxt;
private String blart;
private String belnr;
...etc.
然后将每个字段的 JCoTable 的每一行映射到一个数组列表:
static ArrayList<ClaimTableProperties> claimstable = new ArrayList<ClaimTableProperties>();
JCoTable claims = function.getTableParameterList().getTable("CLAIM_DETAILS");
claims.firstRow();
int rownums = claims.getNumRows();
ClaimTableProperties[] ctp = new ClaimTableProperties[rownums];
for (int i = 0; i < rownums; i++) {
ctp[i] = new ClaimTableProperties();
ctp[i].setBelnr(claims.getString("BELNR"));
ctp[i].setBktxt(claims.getString("BKTXT"));
ctp[i].setZuonr(claims.getString("ZUONR"));
ctp[i].setBlart(claims.getString("BLART"));
claimstable.add(ctp[i]);
claims.nextRow();
} // End for
在您的 servlet 中,设置属性以便您的 jsp 知道它
ArrayList<ClaimTableProperties> claims = dgc.returnClaimsTable();
request.setAttribute("claimstable", claims);
然后在jsp上,使用JSTL输出每个必填字段:
<table>
<c:forEach items="${claimstable}" var="claim">
<tr>
<td>${claim.belnr}</td>
<td>${claim.bktxt}</td>
<td>${claim.zuonr}</td>
<td>${claim.blart}</td>
</tr>
</c:forEach>
</table>