カテゴリ: Thymeleaf 更新日: 2025/06/03

Thymeleafの#datesユーティリティとは?初心者向け日付操作ガイド

Thymeleafの#datesのユーティリティ
Thymeleafの#datesのユーティリティ

先生と生徒の会話形式で理解しよう

生徒

「Thymeleafで日付を操作する方法が知りたいです。例えば、現在の日付をフォーマットして表示したい場合はどうすればいいですか?」

先生

「Thymeleafには#datesという便利なユーティリティが用意されています。これを使えば日付の操作やフォーマットが簡単にできますよ。」

生徒

「具体的にどのように使うのか教えてください!」

先生

「それでは、#datesの基本的な使い方を見ていきましょう。」

1. #datesユーティリティの基本

1. #datesユーティリティの基本
1. #datesユーティリティの基本

Thymeleafの#datesユーティリティは、テンプレート内で日付を操作するためのツールです。日付のフォーマット、現在の日付の取得、日付の加算や減算など、幅広い機能を提供しています。 まず、現在の日付をフォーマットして表示する基本的な例を見てみましょう。


<p th:text="${#dates.format(today, 'yyyy-MM-dd')}"></p>

このコードでは、変数todayに現在の日付が格納されていると仮定し、フォーマットされた日付(例: 2025-01-27)が表示されます。

2. 日付のフォーマットをカスタマイズする

2. 日付のフォーマットをカスタマイズする
2. 日付のフォーマットをカスタマイズする

#dates.formatを使えば、日付を任意のフォーマットで表示できます。以下は、年月日を日本語形式で表示する例です。


<p th:text="${#dates.format(today, 'yyyy年MM月dd日')}"></p>

このコードを実行すると、「2025年01月27日」のように日本語形式の日付が表示されます。地域や用途に合わせてフォーマットを柔軟に変更できるのが特徴です。

3. 現在の日付と時刻を取得する

3. 現在の日付と時刻を取得する
3. 現在の日付と時刻を取得する

#datesには、現在の日付や時刻を直接取得する機能もあります。以下のコードは、現在の日付と時刻をそれぞれ取得して表示する例です。


<p th:text="${#dates.format(#dates.createNow(), 'yyyy-MM-dd HH:mm:ss')}"></p>

#dates.createNow()は現在の日付と時刻を生成します。この例では、現在の日付と時刻を「2025-01-27 15:30:45」のような形式で表示します。

4. 日付の加算と減算

4. 日付の加算と減算
4. 日付の加算と減算

#datesを使えば、日付の加算や減算も簡単に行えます。以下は、1週間後の日付と1週間前の日付を表示する例です。


<p th:text="${#dates.format(#dates.addDays(today, 7), 'yyyy-MM-dd')}"></p>
<p th:text="${#dates.format(#dates.addDays(today, -7), 'yyyy-MM-dd')}"></p>

これにより、「1週間後」や「1週間前」の日付を動的に計算して表示できます。他にも、月や年単位での加算・減算が可能です。

5. 日付の比較

5. 日付の比較
5. 日付の比較

日付の比較を行う場合も#datesが役立ちます。以下は、現在の日付が特定の日付よりも前か後かを判定する例です。


<p th:text="${#dates.isBefore(today, '2025-01-01')} ? '過去の日付です' : '未来の日付です'"></p>

このコードでは、現在の日付が「2025-01-01」よりも前の場合に「過去の日付です」と表示し、それ以外の場合は「未来の日付です」と表示します。

6. 実践例: 日付を動的に表示する

6. 実践例: 日付を動的に表示する
6. 実践例: 日付を動的に表示する

以下は、実際のテンプレート内で日付を動的に操作する例です。このコードでは、現在の日付、1週間後、1週間前の日付をそれぞれ表示しています。


<p>現在の日付: <span th:text="${#dates.format(today, 'yyyy-MM-dd')}"></span></p>
<p>1週間後の日付: <span th:text="${#dates.format(#dates.addDays(today, 7), 'yyyy-MM-dd')}"></span></p>
<p>1週間前の日付: <span th:text="${#dates.format(#dates.addDays(today, -7), 'yyyy-MM-dd')}"></span></p>

このように#datesを活用することで、テンプレート内での日付操作が簡単になります。

7. まとめ

7. まとめ
7. まとめ

本記事では、Thymeleafの#datesユーティリティについて解説しました。#datesを使用することで、日付や時刻の操作がテンプレート内で簡単に行えるようになります。具体的には、日付のフォーマット、現在の日付の取得、日付の加算・減算、さらには日付の比較まで幅広く対応しています。

例えば、日付を「yyyy-MM-dd」形式でフォーマットする方法や、「1週間後」や「1週間前」の日付を動的に計算する方法、さらには日本語形式で日付を表示する方法について詳しく紹介しました。これにより、ユーザーにとって見やすい形で日付を表示することが可能になります。

以下に、今回の記事で紹介したコードを再掲します。自分のプロジェクトで活用してみてください。


<p>現在の日付: <span th:text="${#dates.format(today, 'yyyy-MM-dd')}"></span></p>
<p>1週間後の日付: <span th:text="${#dates.format(#dates.addDays(today, 7), 'yyyy-MM-dd')}"></span></p>
<p>1週間前の日付: <span th:text="${#dates.format(#dates.addDays(today, -7), 'yyyy-MM-dd')}"></span></p>
<p>日付の比較: <span th:text="${#dates.isBefore(today, '2025-01-01')} ? '過去の日付です' : '未来の日付です'"></span></p>
<p>日本語形式の日付: <span th:text="${#dates.format(today, 'yyyy年MM月dd日')}"></span></p>

#datesは、日付を扱うWebアプリケーションでは欠かせない機能です。これを活用することで、バックエンドでの日付処理を減らし、テンプレート側で簡潔に操作できるようになります。

先生と生徒の振り返り会話

生徒

「今回の記事で、#datesユーティリティの便利さがよく分かりました!特に、日付の加算やフォーマット機能が役立ちそうです。」

先生

「そうですね。日付操作は多くのアプリケーションで必要とされるので、#datesを活用することで、コードの簡潔さと可読性が向上しますよ。」

生徒

「次は実際にプロジェクトで試してみます!他にも応用例があれば教えてください。」

先生

「いいですね!実践する中でわからないことがあれば、また質問してくださいね。」

カテゴリの一覧へ
新着記事
Springの@Transactional徹底解説!トランザクションの伝播・分離レベル・タイムアウトの基本
JavaのHashMapクラスgetメソッドの使い方を完全ガイド!初心者でもわかるjava.util入門
Thymeleafのth:fragmentを使ったテンプレートの再利用方法を完全ガイド!初心者でもわかる使い方
Javaの@PathVariableアノテーションの使い方を徹底解説!初心者でもわかるパスパラメータの基本と応用
人気記事
No.1
Java&Spring記事人気No1
Javaのラムダ式で配列を扱う!Arrays.streamの基本と注意点を初心者向けに解説
No.2
Java&Spring記事人気No2
JavaのRuntimeExceptionを完全解説!初心者でもわかるjava.langパッケージの基礎
No.3
Java&Spring記事人気No3
Spring BootとJavaの互換性一覧!3.5/3.4/3.3はJava 21・17に対応してる?
No.4
Java&Spring記事人気No4
JavaのIntegerクラスの使い方を完全ガイド!初心者でもわかる整数操作
No.5
Java&Spring記事人気No5
JavaのBigDecimalクラスcompareToメソッド完全ガイド!初心者でもわかる大小比較の基本
No.6
Java&Spring記事人気No6
Springの@Serviceアノテーションの使い方を徹底解説!初心者でもわかるSpring フレームワーク入門
No.7
Java&Spring記事人気No7
Javaの@SuppressWarningsアノテーションの使い方を完全ガイド!初心者でもわかる警告の抑制方法
No.8
Java&Spring記事人気No8
JavaのHttpSessionを徹底解説!初心者でもわかるセッション管理の基本