ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
Thymeleaf とは
Thymeleaf は HTML5 と互換のあるテンプレートエンジン。Spring Boot の標準的なビュー技術として広く使われます。最大の特徴は 「ブラウザでテンプレートを直接開いてもデザインが崩れない」こと (Natural Templates) で、JSP の代替としてデファクトの座にあります。
導入手順 (Spring Boot)
1. 依存関係の追加
<!-- pom.xml -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
<!-- Spring Web -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
Gradle の場合:
// build.gradle
dependencies {
implementation 'org.springframework.boot:spring-boot-starter-thymeleaf'
implementation 'org.springframework.boot:spring-boot-starter-web'
}
2. ディレクトリ構成
src/main/
├── java/com/example/demo/
│ ├── DemoApplication.java
│ └── HelloController.java
└── resources/
├── application.properties
├── static/
│ └── css/style.css
└── templates/
├── index.html
└── layout/base.html
3. Controller
// HelloController.java
package com.example.demo;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
@Controller
public class HelloController {
@GetMapping("/")
public String index(Model model) {
model.addAttribute("name", "太郎");
model.addAttribute("messages", List.of("こんにちは", "Hello", "Bonjour"));
return "index"; // → src/main/resources/templates/index.html
}
}
4. テンプレート (index.html)
<!DOCTYPE html>
<html lang="ja" xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8">
<title>Thymeleaf サンプル</title>
</head>
<body>
<h1>こんにちは、<span th:text="${name}">ゲスト</span> さん</h1>
<ul>
<li th:each="msg : ${messages}" th:text="${msg}">メッセージ</li>
</ul>
</body>
</html>
ブラウザで開くと「ゲスト」「メッセージ」と表示される (Natural Templates)。Spring Boot 経由なら動的に「太郎」「こんにちは / Hello / Bonjour」に置き換わります。
5. 起動と確認
# Maven
mvn spring-boot:run
# Gradle
./gradlew bootRun
# ブラウザで http://localhost:8080/ にアクセス
主要な Thymeleaf 属性
| 属性 | 用途 | 例 |
|---|---|---|
th:text | テキスト置換 (HTML エスケープ) | <span th:text="${name}"></span> |
th:utext | テキスト置換 (エスケープなし) | <div th:utext="${html}"></div> |
th:if / th:unless | 条件分岐 | <p th:if="${user.admin}">管理者</p> |
th:switch / th:case | switch | 後述 |
th:each | 繰り返し | <li th:each="m : ${list}"></li> |
th:href | リンク URL | <a th:href="@{/users/{id}(id=${u.id})}"> |
th:src | 画像 URL | <img th:src="@{/img/logo.png}"> |
th:action | フォーム action | <form th:action="@{/login}"> |
th:value | input の値 | <input th:value="${name}"> |
th:field | フォームバインディング | <input th:field="*{name}"> |
th:object | フォームオブジェクト | <form th:object="${user}"> |
th:fragment | 断片定義 | <div th:fragment="header"> |
th:insert / th:replace | 断片の埋め込み | <div th:replace="~{layout/base :: header}"> |
th:class | class 属性 | <div th:class="${active} ? 'active' : ''"> |
条件・繰り返しの例
<!-- if / unless -->
<p th:if="${user.admin}">管理者専用</p>
<p th:unless="${user.admin}">一般ユーザ向け</p>
<!-- switch -->
<div th:switch="${role}">
<p th:case="'admin'">管理者</p>
<p th:case="'user'">一般</p>
<p th:case="*">ゲスト</p> <!-- default -->
</div>
<!-- each + iterStat -->
<tr th:each="item, stat : ${items}">
<td th:text="${stat.count}">1</td> <!-- 1 始まりカウント -->
<td th:text="${stat.index}">0</td> <!-- 0 始まりインデックス -->
<td th:text="${stat.size}">10</td> <!-- 総数 -->
<td th:text="${stat.first} ? '先頭' : ''"></td>
<td th:text="${stat.last} ? '末尾' : ''"></td>
<td th:text="${item.name}"></td>
</tr>
URL 表現 @{...}
<!-- 静的リソース -->
<link rel="stylesheet" th:href="@{/css/style.css}">
<img th:src="@{/img/logo.png}">
<!-- パスパラメータ -->
<a th:href="@{/users/{id}(id=${user.id})}">詳細</a>
<!-- → /users/123 -->
<!-- クエリパラメータ -->
<a th:href="@{/search(q=${keyword},page=${page})}">検索</a>
<!-- → /search?q=java&page=2 -->
<!-- 外部 URL -->
<a th:href="@{https://example.com/(ref=${ref})}">外部</a>
レイアウト (Fragment)
<!-- templates/layout/base.html -->
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8">
<title th:text="${title}">タイトル</title>
</head>
<body>
<header th:fragment="header">
<h1>サイト名</h1>
<nav>...</nav>
</header>
<footer th:fragment="footer">
<p>© 2026</p>
</footer>
</body>
</html>
<!-- templates/index.html で利用 -->
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<body>
<div th:replace="~{layout/base :: header}"></div>
<main>
<h2>本文</h2>
</main>
<div th:replace="~{layout/base :: footer}"></div>
</body>
</html>
application.properties の設定
# キャッシュ (開発中は false)
spring.thymeleaf.cache=false
# テンプレートディレクトリ
spring.thymeleaf.prefix=classpath:/templates/
spring.thymeleaf.suffix=.html
# モード (LEGACYHTML5 で XHTML 強制を緩和)
spring.thymeleaf.mode=HTML
# 文字コード
spring.thymeleaf.encoding=UTF-8
# Content-Type
spring.thymeleaf.servlet.content-type=text/html
FAQ
Q: 変更がブラウザに反映されない
A: spring.thymeleaf.cache=false + Spring Boot DevTools 導入。
Q: テンプレートが見つからない
A: ファイルが src/main/resources/templates/ 下にあるか、Controller の戻り値の文字列とファイル名が一致しているか確認。拡張子は付けない。
Q: th:text と th:utext の使い分け
A: 通常は th:text (XSS 対策)。HTML を出力したい安全なデータだけ th:utext。
📸 参考画像
※ 旧バージョンから引き継いだ参考画像です。手順・図解の補助としてご覧ください。

ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページ
子ページはありません
同階層のページ
- 導入方法と基本動作
- メッセージ式
- テンプレートフラグメント(ヘッダー等の共有化)
人気ページ
- 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
- MAC アドレスフィルタリングの仕組みと限界 | ネットワーク入門 NEW 2026-06-22 12:19:10
- VPNとは|暗号トンネル・サイト間/リモートアクセス・IPsec/SSL-VPN/WireGuardを解説 NEW 2026-06-22 12:19:10
- WebRTC とは ブラウザ間 P2P の音声・映像・データ通信 | ネットワーク入門 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
- 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
- WebSocket とは 全二重リアルタイム通信 ws/wss | ネットワーク入門 NEW 2026-06-22 12:17:25
- 証明書と認証局(CA)とは|X.509・信頼チェーン・DV/OV/EV・失効(CRL/OCSP)を解説 NEW 2026-06-22 12:17:24
- ファイアウォールとは|パケットフィルタ・ステートフル・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
- CDN とは エッジキャッシュ・TTL・Cloudflare/CloudFront | ネットワーク入門 NEW 2026-06-22 12:17:24
- TLS/SSLの仕組み|ハンドシェイク・暗号スイート・前方秘匿性・証明書検証をわかりやすく解説 NEW 2026-06-22 12:17:24
コメントを削除してもよろしいでしょうか?