質問するログイン新規登録

Q&A

0回答

341閲覧

layout:fragmentを利用してhtmlを結合する

JackOguro

総合スコア4

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Spring

Spring Framework は、Javaプラットフォーム向けのオープンソースアプリケーションフレームワークです。 Java Platform上に、 Web ベースのアプリケーションを設計するための拡張機能が数多く用意されています。

Thymeleaf

Thymeleaf(タイムリーフ)とは、Java用のテンプレートエンジンで、特定のフレームワークに依存せず使用することが可能です。

Spring Boot

Spring Bootは、Javaのフレームワークの一つ。Springプロジェクトが提供する様々なフレームワークを統合した、アプリケーションを高速で開発するために設計されたフレームワークです。

0グッド

0クリップ

投稿2022/11/11 12:17

0

0

前提

thymeleaf.layoutを使用した画面の結合を行いたいです。
メイン画面のindex.htmlとヘッダー画面のheader.htmlはlayout:replaceを用いて結合して表示することができたのですが、
メイン画面のindex.htmlとフッター画面のfooter.htmlをlayout:fragmentを用いて結合して表示することができませんでした。

実現したいこと

ここに実現したいことを箇条書きで書いてください。

  • 複数のHTMLファイルを1つのHTMLに結合させて表示する

発生している問題・エラーメッセージ

イメージ説明

該当のソースコード

pom.xml

1    <!-- 省略 --> 2 <!-- thymeleaf-layout-dialect --> 3 <dependency> 4 <groupId>nz.net.ultraq.thymeleaf</groupId> 5 <artifactId>thymeleaf-layout-dialect</artifactId> 6 </dependency> 7    <!-- 省略 -->

index.html

1<!DOCTYPE html> 2<html xmlns:th="http://www.thymeleaf.org" 3xmlns:layout="http://www.ultraq.net.nz/thymeleaf/layout"> 4<head> 5<meta charset="UTF-8"> 6<meta name="viewport" content="width=divice-width, initial-scale=1, shrink-to-fit=no"> 7<title>レイアウト</title> 8</head> 9<body> 10<!-- ヘッダー --> 11<div layout:replace="~{html/header::header}"></div> 12<!-- フッター --> 13<div layout:fragment="footer"></div> 14</body> 15</html>

header.html

1<!DOCTYPE html> 2<html xmlns:th="http://www.thymeleaf.org" 3xmlns:layout="http://www.ultraq.net.nz/thymeleaf/layout" 4layout:decorate="~{/index}"> 5<head> 6<meta charset="UTF-8"> 7<title>Insert title here</title> 8</head> 9<body> 10 <div layout:fragment="header"> 11 ここはヘッダーです 12 </div> 13</body> 14</html>

footer.html

1<!DOCTYPE html> 2<html xmlns:th="http://www.thymeleaf.org" 3xmlns:layout="http://www.ultraq.net.nz/thymeleaf/layout" 4layout:decorate="~{/index}"> 5<head> 6<meta charset="UTF-8"> 7<title>Insert title here</title> 8</head> 9<body> 10 <div layout:fragment="footer"> 11 ここはフッターです 12 </div> 13</body> 14</html>

オブジェクトツリー
イメージ説明

試したこと

  1. pom.xmlにthymeleaf-layout-dialectのライブラリを追加する。
  2. メインのindex.html内のフッターを読み込ませたい箇所に<div layout:fragment="footer"></div>を記述する
  3. 読込み先のfooter.htmlをindex.htmlと紐付けるために<html>タグにlayout:decorate="~{/index}と<div>タグにlayout:fragment="footer"と記述する。

補足情報(FW/ツールのバージョンなど)

spring boot バージョン 2.7.5

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.29%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問