プレーンHTMLではできません。最初の質問タイトルにHTMLを記述しましたが、javabeans
タグを付けてc:forEach
というタグを記述しているので、HTMLではなくJSPとJSTLを意味すると思います。
ここでは、JSP + JSTLソリューションが、より読みやすくなるように書式設定されています。 Beanコード:
package com;
public class TransferBean {
private int[][] _boardArray = {
{ 1, 2, 33, 0, 7},
{ 13, 11, 7, 5, 3},
{ 5, 3, 2, 1, 1},
};
public int[][] getBoardArray() {
return _boardArray;
}
public int getBoardArrayRowLength() {
if (_boardArray == null || _boardArray.length == 0
|| _boardArray[0] == null) {
return 0;
}
return _boardArray[0].length;
}
}
ここでJSPファイルの内容:
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<jsp:useBean id="bean" class="com.TransferBean" />
<table>
<thead>
<tr>
<c:forEach var="i" begin="1" end="${bean.boardArrayRowLength}">
<th>Column ${i}</th>
</c:forEach>
</tr>
</thead>
<tbody>
<c:forEach var="row" items="${bean.boardArray}">
<tr>
<c:forEach var="column" items="${row}">
<td>
${column}
</td>
</c:forEach>
</tr>
</c:forEach>
</tbody>
</table>
は、アレイ内容は、2つの入れ子c:forEach
ループによってレンダリングされます。外側のループが行を反復処理し、各行に対して、ネストされたループが指定された行の列を反復処理します。
上記の例は、ブラウザでは次のようになります。