ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
エラー内容
Struts 1.x の JSP で以下のように書くとコンパイル時に怒られます:
<%@ taglib uri="http://struts.apache.org/tags-html" prefix="html" %>
<!-- ❌ NG: TLD によると、タグ form の属性 id は無効です -->
<html:form action="/login" id="loginForm" class="form-horizontal">
<html:text property="username" id="usernameInput" />
</html:form>TLDによると、タグ form の属性 id は無効です
According to TLD, attribute id is not valid for tag form.
原因
Struts 1.x の HTML タグライブラリ(<html:form>、<html:text> 等)は標準 HTML 属性をそのまま受け取れない仕様になっています。これは Struts が独自属性で値を上書き/管理する都合上、ぶつかる可能性のある名前を別名にしているためです。
主に名前がぶつかる属性は以下で、それぞれ別名が用意されています:
| 標準 HTML 属性 | Struts での書き方 | 出力される HTML 属性 |
|---|---|---|
id | styleId | id |
class | styleClass | class |
style | style (そのまま) | style |
name | property | name |
value | value または ActionForm の値 | value |
対処: styleId / styleClass に書き換える
<!-- ✅ OK -->
<html:form action="/login" styleId="loginForm" styleClass="form-horizontal">
<html:text property="username" styleId="usernameInput" styleClass="form-control" />
<html:password property="password" styleId="passwordInput" styleClass="form-control" />
<html:submit styleClass="btn btn-primary">ログイン</html:submit>
</html:form>
出力される HTML は通常通りで、ブラウザ側は id="loginForm" として認識します:
<form action="/login.do" name="loginForm" method="post"
id="loginForm" class="form-horizontal">
<input type="text" name="username" value=""
id="usernameInput" class="form-control">
<input type="password" name="password" value=""
id="passwordInput" class="form-control">
<input type="submit" value="ログイン" class="btn btn-primary">
</form>
CSS / JavaScript からの参照
変更不要。出力される属性名は id / class のままなので、CSS セレクタや document.getElementById()、jQuery セレクタ $('#loginForm') はそのまま動作します。
// styleId を使っても JS からは id として参照可能
$('#loginForm').on('submit', function(e) {
if ($('#usernameInput').val() === '') {
alert('ユーザー名を入力してください');
e.preventDefault();
}
});
その他の Struts 1 タグでも同じパターン
同じ属性名のリネームは、<html:text> / <html:select> / <html:checkbox> / <html:radio> 等すべての HTML 系タグで共通です:
<html:select property="category" styleId="categorySelect" styleClass="form-select">
<html:option value="1">食品</html:option>
<html:option value="2">飲料</html:option>
</html:select>
<html:checkbox property="agree" styleId="agreeCheck" styleClass="form-check-input" />
Struts 2 の場合は異なる
Struts 2 では設計が刷新されており、id / cssClass という属性名になっています:
<!-- Struts 2 -->
<%@ taglib prefix="s" uri="/struts-tags" %>
<s:form action="login" id="loginForm" cssClass="form-horizontal">
<s:textfield name="username" id="usernameInput" cssClass="form-control" />
</s:form>
| Struts 1 | Struts 2 | |
|---|---|---|
| id | styleId | id(そのまま) |
| class | styleClass | cssClass |
| style | style | cssStyle |
関連エラー
- 「タグ form の属性 class は無効です」 — 同じパターン。
styleClassに変更 - 「タグ ... の属性 name は無効です」 — Struts は ActionForm のフィールド名を
propertyで受ける - 「タグ ... の属性 onclick は無効です」 — Struts 1 では一部のイベント属性も別名が必要(バージョン依存)
まとめ
Struts 1 のタグライブラリは標準 HTML とは別の独自仕様。以下を覚えておけば大体の TLD エラーは解決:
- id → styleId
- class → styleClass
- name → property(フィールド連携の場合)
- その他は Struts HTML Tag Library Reference を確認
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページ
子ページはありません
同階層のページ
- createActionFormにてNullPointerException
- java.lang.NullPointerException: Module 'null' not found
- javax.servlet.jsp.JspException: Cannot find bean org.apache.struts.taglib.html.BEAN in any scope
- Description Resource Path Location Type cvc-complex-type.2.4.a: Invalid content was found starting with element 'X'
- パス ... に対するアクションのインスタンスがありません
- TLDによると、タグ form の属性 id は無効です
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- IPv6とは|128bitアドレス・コロン16進表記/::省略・リンクローカル・SLAAC・デュアルスタック NEW 2026-06-22 12:34:44
- VPNとは|暗号トンネル・サイト間/リモートアクセス・IPsec/SSL-VPN/WireGuardを解説 NEW 2026-06-22 12:19:10
- MAC アドレスフィルタリングの仕組みと限界 | ネットワーク入門 NEW 2026-06-22 12:19:10
- WebRTC とは ブラウザ間 P2P の音声・映像・データ通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- gRPC とは HTTP/2 + Protocol Buffers の高速 RPC | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/3 (QUIC) とは UDP ベースの低遅延 Web 通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/2 とは 多重化・HPACK・バイナリフレーム | ネットワーク入門 NEW 2026-06-22 12:17:25
- Web通信プロトコル入門 HTTP/2・HTTP/3・WebSocket・gRPC・WebRTC | ネットワーク入門 NEW 2026-06-22 12:17:25
- WebSocket とは 全二重リアルタイム通信 ws/wss | ネットワーク入門 NEW 2026-06-22 12:17:25
- ファイアウォールとは|パケットフィルタ・ステートフル・DMZ・次世代FW(L4/L7)を解説 NEW 2026-06-22 12:17:24
- iptables/nftablesとは|テーブル・チェーン・ルール例・永続化をLinux視点で解説 NEW 2026-06-22 12:17:24
- HAProxy とは frontend/backend と設定例 | ネットワーク入門 NEW 2026-06-22 12:17:24
- 証明書と認証局(CA)とは|X.509・信頼チェーン・DV/OV/EV・失効(CRL/OCSP)を解説 NEW 2026-06-22 12:17:24
- CDN とは エッジキャッシュ・TTL・Cloudflare/CloudFront | ネットワーク入門 NEW 2026-06-22 12:17:24
- TLS/SSLの仕組み|ハンドシェイク・暗号スイート・前方秘匿性・証明書検証をわかりやすく解説 NEW 2026-06-22 12:17:24
コメントを削除してもよろしいでしょうか?