プロパティファイルをロードし、100個のテストケース名のリストをArrayListオブジェクトに含めるサーブレットがあります。サーブレットをロードした後、リストをテーブルに表示するJSPに転送します。リストは長いので、たとえば、JSPで3つまたは4つの列に分割されるように、テーブルに表示するためのエレガントな方法が必要です。
私が今していることは、サーブレットでリストを3つのサブリストに分割することです。
//load properties
Properties props = new Properties();
ArrayList<String> tests = new ArrayList<String>();
props.load(getServletContext().getResourceAsStream("/WEB-INF/sailcertifier.properties"));
Pattern pattern = Pattern.compile("[A-Z]{3}-[0-9]{2}");
for (Enumeration<Object> e = props.keys(); e.hasMoreElements();) {
String key = (String) e.nextElement();
Matcher m = pattern.matcher(key);
if (m.find())
tests.add(key);
}
Collections.sort(tests, new TestOrderComparator());
confBean.setPossibleTests(tests.toArray(new String[tests.size()]));
int third = tests.size() / 3;
List<String> testSubset1 = tests.subList(0, third);
List<String> testSubset2 = tests.subList(third, third * 2);
List<String> testSubset3 = tests.subList(third * 2, tests.size());
//store the bean as a request attribute
request.setAttribute("testSet1", testSubset1.toArray(new String[testSubset1.size()]));
request.setAttribute("testSet2", testSubset2.toArray(new String[testSubset2.size()]));
request.setAttribute("testSet3", testSubset3.toArray(new String[testSubset3.size()]));
request.setAttribute("testsConf", confBean);
request.setAttribute("certProps", props);
//forward to tests selection page
String url = "/sailcertifier/jsp/testsSelection.jsp";
RequestDispatcher dispatcher = getServletContext().getRequestDispatcher(url);
response.setContentType("application/javascript");
try {
dispatcher.forward(request, response);
} catch (ServletException e) {
e.printStackTrace();
}
JSPでは、次のようにサブリストを繰り返し処理します(それぞれの場合にいくつかのhtml要素を追加します)。
<table>
<tr>
<td style="width: 33%">
<table>
<tr>
<td>
<c:forEach var="testName" items="${testSet1}">
<tr>
<td><label for="${testName}" id=${testName}Label>${testName}</label></td>
<td><input id=${testName} type="checkbox" value=${testName} name="selTest"></input></td>
<td><input id=${testName}Run type="button" value="Run Test" name="runButtons" /></td>
<td><input id=${testName}ManPass type="button" value="Manual Pass" name="manPassButtons"/></td>
<td><div id=${testName}Status style="width:100px"></td>
<td></td>
<td></td>
</tr>
</c:forEach>
<tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr>
</td>
</tr>
</table>
</td>
<td style="width: 33%">
<table>
<tr>
<td>
<c:forEach var="testName" items="${testSet2}">
<tr>
<td><label for="${testName}" id=${testName}Label>${testName}</label></td>
<td><input id=${testName} type="checkbox" value=${testName} name="selTest"></input></td>
<td><input id=${testName}Run type="button" value="Run Test" name="runButtons" /></td>
<td><input id=${testName}ManPass type="button" value="Manual Pass" name="manPassButtons"/></td>
<td><div id=${testName}Status style="width:100px"></td>
<td></td>
<td></td>
</tr>
</c:forEach>
<tr><td></td><td></td><td></td><td></td><td></td><td></td><td></td></tr>
</td>
</tr>
</table>
</td>
<td style="width: 33%">
<table>
<tr>
<td>
<c:forEach var="testName" items="${testSet3}">
<tr>
<td><label for="${testName}" id=${testName}Label>${testName}</label></td>
<td><input id=${testName} type="checkbox" value=${testName} name="selTest"></input></td>
<td><input id=${testName}Run type="button" value="Run Test" name="runButtons" /></td>
<td><input id=${testName}ManPass type="button" value="Manual Pass" name="manPassButtons"/></td>
<td><div id=${testName}Status style="width:100px"></td>
<td></td>
</tr>
</c:forEach>
</td>
</tr>
</table>
</td>
</tr>
</table>
3つのJSTLforループを使用するのはちょっと醜いことを認めます(完全な元のリストを使用することはまだ理解されていません)。jqueryプラグイン( jqueryグリッドプラグインなど)または他のライブラリ(displaytag?)を使用して、行への分割を均等に処理することで、これを処理するためのよりクリーンな方法はありますか?