etc/CHEAT SHEET

타임리프 기본 설정

기억용블로그 2022. 5. 23. 23:14
728x90

타임리프 기본 설정

 

application.properties에 작성

#Thymeleaf
//템플릿의 위치와 확장자 정의
spring.thymeleaf.prefix=classpath:/templates/
spring.thymeleaf.suffix=.html
//true일시 정의된 위치에 템플릿이 없으면 에러 발생.
spring.thymeleaf.check-template-location=true
//개발용 설정. 정적 자원을 바로 반영하기 위함. 배포시엔 true
spring.thymeleaf.cache=false
#Hot loader
//true일시 정적 자원 실시간 반영
spring.devtools.livereload.enabled=true
//true일시 변화를 감지하고 자동으로 재시작
spring.devtools.remote.restart.enabled=true

레이아웃 작성하기

 

build.gradle에 작성

implementation group: 'nz.net.ultraq.thymeleaf', name: 'thymeleaf-layout-dialect', version: '2.4.1'

 

templates/layouts/layout.html 작성

 

thymeleaf + thymeleaf security + bootstrap 5.2 + fontawesome 5.8.2 + 한국어 폰트 설정

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml"
      xmlns:th="http://www.thymeleaf.org"
      xmlns:layout="http://www.ultraq.net.nz/thymeleaf/layout"
      xmlns:sec="http://www.w3.org/1999/xhtml">

<head>
    <!-- Required meta tags -->
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <meta name="description" content="">
    <meta name="author" content="Mark Otto, Jacob Thornton, and Bootstrap contributors">
    <meta name="generator" content="Hugo 0.98.0">

    <link rel="icon" href="data:;base64,iVBORw0KGgo=">

    <!-- CSS -->
    <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.2.0-beta1/dist/css/bootstrap.min.css"
          rel="stylesheet" integrity="sha384-0evHe/X+R7YkIZDRvuzKMRqM+OrBnVFBL6DOitfPri4tjfHxaWutUpFmBp4vmVor" crossorigin="anonymous">

    <link href="../assets/dist/css/bootstrap.min.css" rel="stylesheet">

    <!-- font-awesome -->
    <link
            rel="stylesheet"
            href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.8.2/css/all.min.css"
    />
    <link href="https://fonts.googleapis.com/css?family=Noto+Sans+KR&display=swap" rel="stylesheet">

    <style>
    input::-webkit-inner-spin-button {
    appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none;
    }


    .font01 {
        font-family: 'Noto Sans KR', sans-serif;
      }

      .bd-placeholder-img {
        font-size: 1.125rem;
        text-anchor: middle;
        -webkit-user-select: none;
        -moz-user-select: none;
        user-select: none;
      }

      @media (min-width: 768px) {
        .bd-placeholder-img-lg {
          font-size: 3.5rem;
        }
      }

      .b-example-divider {
        height: 3rem;
        background-color: rgba(0, 0, 0, .1);
        border: solid rgba(0, 0, 0, .15);
        border-width: 1px 0;
        box-shadow: inset 0 .5em 1.5em rgba(0, 0, 0, .1), inset 0 .125em .5em rgba(0, 0, 0, .15);
      }

      .b-example-vr {
        flex-shrink: 0;
        width: 1.5rem;
        height: 100vh;
      }

      .bi {
        vertical-align: -.125em;
        fill: currentColor;
      }

      .nav-scroller {
        position: relative;
        z-index: 2;
        height: 2.75rem;
        overflow-y: hidden;
      }

      .nav-scroller .nav {
        display: flex;
        flex-wrap: nowrap;
        padding-bottom: 1rem;
        margin-top: -1px;
        overflow-x: auto;
        text-align: center;
        white-space: nowrap;
        -webkit-overflow-scrolling: touch;
      }
    </style>
</head>

<body class="font01">
<div th:replace="fragments/navbar :: navbar"></div>

<div layout:fragment="content"></div>

<footer th:replace="fragments/footer :: footer"></footer>

<div th:replace="fragments/commonScript :: commonScript"></div>
</body>
</html>

 

templates/fragments/commonScript.html 작성

JS를 가장 마지막에 두어야 사용자 만족도가 높으므로 따로 분리해서 작성

footer, header, navbar 등도 이와 같이 작성하면 된다.

<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<body>

<div th:fragment="commonScript">
    <!-- JavaScript Bundle with Popper -->
    <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.2.0-beta1/dist/js/bootstrap.bundle.min.js" integrity="sha384-pprn3073KE6tl6bjs2QrFaJGz5/SUsLqktiwsUTF55Jfv3qYSDhgCecCxMW52nD2" crossorigin="anonymous"></script>
    <script src="../assets/dist/js/bootstrap.bundle.min.js"></script>
</div>

</body>
</html>

 

content에 들어갈 부분 작성

layout:fragment="content"라고 명시된 tag의 시작과 끝이 layout.html의 layout:fragment="content"에 들어가게 된다. 

content라는 이름을 가질 필요는 전혀 없음

<!DOCTYPE html>
//layout 기능을 사용할것을 명시
<html xmlns:layout="http://www.ultraq.net.nz/thymeleaf/layout"
//layout의 위치를 정의. 
      layout:decorate="~{layouts/layout.html}">
<head>
    <title>회원가입 완료</title>
</head>
<body>
//content 시작
<div layout:fragment="content">
<h1>회원가입이 완료되었습니다.</h1>
</div>
//content 끝
</body>
</html>