spring - ์™ธ๋ถ€ css/javascript ๋กœ๋”ฉ

2023. 3. 17. 10:21ใ†Spring

์œ„์น˜ : static ํด๋” ์•„๋ž˜ (css/js/img)

์™ธ๋ถ€ css์™€ html ์—ฐ๊ฒฐ ์‹œ link ํƒœ๊ทธ ์‚ฌ์šฉ

title ํƒœ๊ทธ ์•„๋ž˜ ์ž‘์„ฑ

<link rel="stylesheet" href="/css/test.css">

href ์ž‘์„ฑ ์‹œ ์ฃผ์˜!

ccs/js ๊ธฐ์ค€ ํด๋” : static์— ์ ‘๊ทผํ•˜๋ ค๋ฉด ๋ฌด์กฐ๊ฑด ๋งจ ์•ž์— / ์žˆ์–ด์•ผ ๋œ๋‹ค.

 

 

 

fragment ์‚ฌ์šฉ ์‹œ ์™ธ๋ถ€ css, js ์—ฐ๊ฒฐํ•˜๊ธฐ

fragment ์‚ฌ์šฉ ์‹œ ์œ„์™€ ๊ฐ™์ด css/script ์—ฐ๊ฒฐ ํƒœ๊ทธ๋“ค์ด th:block ๋ฐ–์— ์žˆ๊ธฐ ๋•Œ๋ฌธ์— ์ ์šฉ ์•ˆ ๋จ.

๊ทธ๋ฆฌ๊ณ  ํ™”๋ฉด ๋”ฐ๋ผ css, javascript ๋งค๋ฒˆ ๋ฐ”๋€Œ๊ธฐ ๋•Œ๋ฌธ์—  css, javascript๋„ ์—ฐ๊ฒฐ์ด ๋ฐ”๋€” ์ˆ˜ ์žˆ๊ฒŒ layout.html์— ์•„๋ž˜ ์ฝ”๋“œ ์ถ”๊ฐ€

css ์ฝ”๋“œ ์œ„์น˜ : </head> ์ „ 

<th:block layout:fragment="content_css"></th:block>

js ์ฝ”๋“œ ์œ„์น˜ : </body> ํƒœ๊ทธ ์ „ 

<th:block layout:fragment="content_js"></th:block>

fragment.html์—๋Š” ์•„๋ž˜์™€ ๊ฐ™์ด css ๋ถˆ๋Ÿฌ์˜ค๋Š” th:block / content ๋ถˆ๋Ÿฌ์˜ค๋Š” th:block / js ๋ถˆ๋Ÿฌ์˜ค๋Š” th:block ์ˆœ์„œ๋Œ€๋กœ!

<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org"
   xmlns:layout="http://www.ultraq.net.nz/thymeleaf/layout"
   layout:decorate="~{fragment/layout}">

<!-- ์—ฐ๊ฒฐํ•ด์•ผ ํ•  ์™ธ๋ถ€ css ํŒŒ์ผ -->
<th:block layout:fragment="content_css">
	<link rel="stylesheet" href="/css/test.css"> <!-- ์™ธ๋ถ€ css ์—ฐ๊ฒฐํ•˜๋Š” ์ฝ”๋“œ๋ฅผ block ์•ˆ์— ์ž‘์„ฑ layout์—์„œ ๊ฐ™์ด ์—ด์–ด์คŒ -->
</th:block>


<th:block layout:fragment="content">
	<div class="testDiv">fragment ์‚ฌ์šฉ ์‹œ ์™ธ๋ถ€ css, js ์—ฐ๊ฒฐํ•˜๊ธฐ</div>
</th:block>

<!-- ์—ฐ๊ฒฐํ•ด์•ผ ํ•  ์™ธ๋ถ€ js ํŒŒ์ผ-->
<th:block layout:fragment="content_js">
	<script type="text/javascript" src="/js/test.js"></script> <!-- ์™ธ๋ถ€ js ์—ฐ๊ฒฐํ•˜๋Š” ์ฝ”๋“œ๋ฅผ block ์•ˆ์— ์ž‘์„ฑ layout์—์„œ ๊ฐ™์ด ์—ด์–ด์คŒ -->
</th:block>


</html>