Fragments
레이아웃의 기본 공식 : One True Layout
https://m.blog.naver.com/wlwl16/221253244581
새로운 폴더(fragments) 생성 -> html 파일 생성
src/main/resources/templates/fragments/fragment1.html
<!--src/main/resources/templates/exLayout1.html-->
<!DOCTYPE html>
<html lang="ko" xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div th:fragment="part1">
<h2>Part 1</h2>
</div>
<div th:fragment="part2">
<h2>Part 2</h2>
</div>
<div th:fragment="part3">
<h2>Part 3</h2>
</div>
</body>
</html>
src/main/resources/templates/exLayout1.html
templates/sample 안에 exLayout1.html 파일 생성
<!-- src/main/resources/templates/exLayout1.html -->
<!DOCTYPE html>
<html lang="ko" xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<h1>Fragment Test</h1>
<h1>Layout 1 -1</h1>
<div th:replace="~{/fragments/fragment1 :: part1}"></div>
<h1>Layout 1 -2</h1>
<div th:insert="~{/fragments/fragment1 :: part2}"></div>
<h1>Layout 1 -3</h1>
<div th:replace="~{/fragments/fragment1 :: part3}"></div>
</body>
</html>
~{}는 fragement를 url link로 표현 할 때 사용한다
<div>에 <div part1>를 대치 하는 것
<!--replace 된 태그를 완전히 대체-->
<div th:replace="~{/fragments/fragment1 :: part1}"></div>
<div>안에 <div part2>를 넣어준것
<!--insert 있는 태그 안에 추가-->
<div th:insert="~{/fragments/fragment1 :: part2}"></div>
resourses/template 안에있는것을 사용하기 위해서는 Controller에서 선언해주고
index.html 안에 경로를 설정해준다
//src/main/resources/templates/index.html
<a th:href="@{/sample/exLayout1}">/sample/exLayout1</a><br>
//src/main/java/com/example/ex3/controller/SampleController.java
@GetMapping("/exLayout1")
public void exLayout1(){
log.info("exLayout1.......");
}
@GetMapping({" ", " "})
@GetMapping({"/exLayout1", "/exLayout2"})
public void exLayout1(){
log.info("exLayout1.......");
}
{"/exLayout1", "/exLayout2"} 둘다 요청하면 exLayout1() 이 호출된다
fragment2.html /fragment3.html 생성
<!-- src/main/resources/templates/fragments/fragment2.html -->
<div>
<hr/>
<h2>Fragment2 File</h2>
<h2>Fragment2 File</h2>
<h2>Fragment2 File</h2>
<hr/>
</div>
exLayout1 수정하기
Servlet-relative URLs
<!-- src/main/resources/templates/exLayout1.html -->
<h1>Layout 1 -1</h1>
<div style="border: 1px solid blue">
<!-- fragment를 통째로 들고 올 때 :: 는 사용 안함-->
<th:block th:replace="~{/fragments/fragment2}"></th:block>
</div>
<!--src/main/resources/templates/fragments/fragment3.html-->
<!DOCTYPE html>
<html lang="ko" xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div th:fragment="target(first, second)">
<style>
.c1{background-color: red;}
.c2{background-color: blue;}
</style>
<div class="c1">
<th:block th:replace="${first}"></th:block>
</div>
<div class="c2">
<th:block th:replace="${second}"></th:block>
</div>
</div>
</body>
</html>
exLayout2.html 생성
src/main/resources/templates/sample/exLayout2.html
<!--src/main/resources/templates/sample/exLayout2.html-->
<!DOCTYPE html>
<html lang="ko" xmlns:th="http://www.thymeleaf.org">
<th:block th:replace="~{/fragments/fragment3 :: target(~{this:: #ulFirst},~{this :: #ulSecond})}"></th:block>
<ul id ="ulFirst">
<li>AAA</li>
<li>BBB</li>
<li>CCC</li>
</ul>
<ul id ="ulSecond">
<li>111</li>
<li>222</li>
<li>333</li>
</ul>
</html>
fragment3에 있는 c1,c2의 값을
target에 ulFirst, ulSecond 를 던져줘서 대치 해줌
<!--src/main/resources/templates/index.html-->
<a th:href="@{/sample/exLayout2}">/exLayout2</a><br>
layout 폴더와 layout1.html 을 생성해줌
<!--src/main/resources/templates/layout/layout1.html-->
<!DOCTYPE html>
<html lang="ko" xmlns:th="http://www.thymeleaf.org">
<th:block th:fragment="setContent(content)">
<head>
<meta charset="UTF-8">
<title>Title</title>
<!-- vw: 넓이를 100% 기준으로 표시 , vh: 높이를 100% 기준으로 표시-->
<style>
*{ margin :0; padding :0;}
.header{width :100vw; height : 20vh; background-color : red;}
.content{ width :100vw%; height : 70vh; background-color : blue;}
.footer{ width :100vw; height : 10vh;background-color : green;}
</style>
</head>
<body>
<div class="header">
<h1>
HEADER
</h1>
</div>
<div class="content">
<h1>
<th:block th:replace="${content}"></th:block>
</h1>
</div>
<div class="footer">
<h1>
FOOTER
</h1>
</div>
</body>
</th:block>
</html>
<!--src/main/resources/templates/sample/exTemplate.html-->
<!DOCTYPE html>
<html lang="ko" xmlns:th="http://www.thymeleaf.org">
<th:block th:replace="~{layout/layout1 :: setContent(~{this :: content})}">
<th:block th:fragment="content">
<h1>exTempate Page1</h1>
</th:block>
</th:block>
</html>
layout1.html 에있는 setContent 를 exTemplate.html로 가져와서 사용하겠다는 코드
:: 는 해당 부분을 가져오겠다는 것을 의미한다 생각하면 될 듯
<th:block th:replace="~{layout/layout1 :: setContent(~{this :: content})}">
SampleController.java 에 exTemplate 를 사용할 수 있게 세팅해주기
//src/main/java/com/example/ex3/controller/SampleController.java
@GetMapping({"/exLayout1", "/exLayout2","exTemplate"})
public void exLayout1(){
log.info("exLayout1.......");
}
index.html 에 exTemplate로 이동하는 링크 달아줌
<!--src/main/resources/templates/index.html-->
<a th:href="@{/sample/exTemplate}">/exTemplate</a><br>