Spring Boot Layout A to Z
소개
Spring Boot Layout을 위한 Maven 패키지를 추가하여 레이아웃 페이지(마스터 페이지)를 만드는 방법을 알아봅니다.
본 아티클에 대한 데모 소스는 다음 경로에서 살펴볼 수 있습니다.
https://github.com/VisualAcademy/SpringBootLayoutDemo
따라하기
(1) Web, Thymeleaf 패키지가 포함된 JavaCampus 프로젝트 또는 기본 스프링 부트 프로젝트를 생성하고, pom.xml에 thymeleaf-layout-dialect 패키지를 추가합니다. pom.xml 파일의 최소 모양은 다음 코드를 참고하세요.
<코드> pom.xml
</코드>
(2) shared 폴더(또는 원하는 폴더에) _layout.html 파일을 만들고 다음과 같이 코드를 작성합니다.
<코드> /templates/shared/_layout.html
</코드>
(3) Home 컨트롤러의 뷰 페이지를 담당할 index.html 문서를 다음과 같이 작성합니다.
<코드> /templates/index.html
</코드>
(4) HomeController.java 이름으로 Home 컨트롤러를 작성 후 index 액션 메서드를 다음과 같이 작성합니다.
<코드> HomeController.java
</코드>
(5) 프로젝트를 실행 후 레이아웃이 적용된 index 페이지를 확인합니다.
<실행>
</실행>
(6) 자바스크립트 포함를 포함할 때에는 th:block 태그를 사용합니다. 변경된 레이아웃 페이지는 다음과 같습니다.
<코드> _layout.html
</코드>
(7) 따로 자바스크립트 코드를 만들지는 않았지만, JavaScript 파일을 호출하는 코드가 적용된 index 페이지입니다.
<코드> index.html
</코드>
(8) 실행 소스를 확인하면 script 블록이 추가됨을 확인할 수 있습니다.
<실행>
</실행>
(9) 만약, 레이아웃(_layout.html) 페이지에 들어가는 또 다른 부분 페이지(컴포넌트)를 따로 구성할 수도 있습니다. 다음 그림과 같이 views 폴더에 shared 폴더를 두고 이곳에 _header.html과 _footer.html 페이지를 생성할 수 있습니다. 둘 다 헤더 영역과 푸터 영역을 담당하는 간단한 한 줄 짜리 페이지입니다.
<실행>
</실행>
(10) _header.html 페이지는 다음과 같습니다.
<코드> _header.html
</코드>
(11) _footer.html 페이지는 다음과 같습니다.
<코드> _footer.html
</코드>
(12) 다시 변경된 _layout.html 파일의 내용입니다.
<코드> _layout.html
</코드>
(13) 레이아웃과 헤더 그리고 푸터가 포함된 최종 만들어진 index.html 페이지의 실행 결과는 다음과 같습니다.
<실행>
</실행>
마무리
현재 실습을 마무리하면, 스프링 부트에서 부분 페이지 및 전체 레이아웃을 담당하는 페이지를 구현할 수 있습니다.
끝.
Comments
Comments are closed