inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 MVC 1편 - 백엔드 웹 개발 핵심 기술

상품 목록 - 타임리프

templates 하위에 css가 없어도 href="../css/bootstrap.min.css"가 적용되는 이유

해결된 질문

411

11 1

작성한 질문수 147

0

[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)

[질문 내용]


1.jpg

 

위 사진처럼 templates 하위에 css 폴더나 css 파일이 없는 상태이고(css 파일은 /static/css/bootstrap.min.css에 있는 상태)

 

2.jpg

templates/basic/items.html 코드에 <link href="../css/bootstrap.min.css" rel="stylesheet"> 이렇게 상대 경로로만 있는 상태에서 서버를 띄우고 http://localhost:8080/basic/items를 실행하면 css가 적용이 안 될 거라고 예상했습니다. 그런데 css가 적용이 됩니다.

 

위 상대 경로대로면 현재 위치의 상위로 간 다음에 css 경로를 찾아야 하는데 templates 하위엔 css가 없으므로 css 적용이 안 되어야 하지 않나요? 그런데 위 상대 경로로 static에 있는 css를 정상적으로 찾는 이유가 궁금합니다. 그냥 스프링 부트가 알아서 잘 찾아 주는 거라 보면 될까요?

spring mvc

답변 1

2

y2gcoder

안녕하세요.11 1님, 공식 서포터즈 y2gcoder입니다.

서버에서 동적으로 그려내는 타임리프 템플릿 파일(html)은 templates에 있어야 서버에서 클라이언트로 내려주기 전에 동적인 부분을 그려서 완성된 html 파일로 내려보내줄 수 있습니다.

그러면 완성된 html파일을 받은 브라우저(클라이언트)는 해당 html을 분석하여 렌더링하기 시작합니다. 이 때 html 를 렌더링하기 위해 파싱하던 도중 css import 문을 만나면 해당 css 파일을 서버로 요청하고 다시 받습니다.

css 파일을 다시 요청하고 응답받는 것은 클라이언트 쪽의 정적 리소스 요청과 응답에 따른 것이고 이는 서버가 타임리프 템플릿을 동적으로 그려서 완성된 html 파일을 클라이언트에 내려주는 일과는 별개로 이루어집니다! 그래서 static/ 내부에 있는 정적 파일인 css를 받아올 수 있습니다:)

 

감사합니다.

1

11 1

자세한 답변 감사합니다!

servlet과 container에 대한 질문입니다

0

22

1

api를 어느 컨트롤러에 작성해야하는지는 어떤 기준으로 해야하나요?

0

62

1

jsp 의존성 수정 요청

0

77

2

요즘 웹 서버가 주로 사용되는 이유는 SPA 구조 때문일까요 ?

0

142

1

save() 메서드 문의

0

65

1

절대 경로로 templates/basic 하위 파일 열면 css 적용 안되는 현상

0

99

1

request-body-json

0

83

2

MVC 패턴의 적용 단위

0

94

1

RequestMapping을 이용한 핸들러, 어댑터

0

118

2

save 후 결과화면

0

86

2

jsp를 이용한 view

0

97

1

application.properties에 debug 추가해도 결과가 똑같습니다.

0

177

1

수업 코드 제공 관련 문의

0

97

2

RequestMappingHandlerAdapter의 Controller 호출 과정

0

99

3

파일 오픈 시

0

68

1

스프링 배치 관련

0

77

1

@RequestParam의 defaultValue가 blank 값도 처리하는 지 여부

0

112

1

postman으로 /request-body-json-v1 호출시 500 error

0

94

1

프론트엔드와 백엔드의 mvc, rest api에 대한 질문

0

78

1

모델의 역할과 계층 분리에 대한 이해 차이 + 추가질문

0

111

1

console log 출력 관련 질문입니다.

0

74

1

애플리케이션이 실행 되지 않습니다 ㅠㅠㅠ

0

138

1

html 변경하는 부분 적용 문제

0

103

1

한글 깨짐

0

76

2