inflearn logo
강의

Course

Instructor

Spring MVC Part 1 - Core technologies for backend web development

Product Details

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

Resolved

99

rkqkdrn21947

6 asked

0


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

[질문 내용]

templates 에 css 추가하여 해결 했습니다.

image.png

 


html 하위에 ~~~.html 파일들은 css 가 적용되어 열립니다.

image.png

templates/baisc 하위 ~~~.html 은 이렇게 뼈만 앙상하게 나오는데 강의 에서는 templates 의 하위 html 파일에서도 css 폼이 적용 되어 나오는데 따로 설정 방법이나 변경 사항이 있는걸까요 ?

image.png
<!DOCTYPE HTML> 
<html xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="utf-8">
    <link th:href="@{/css/bootstrap.min.css}"
          href="../css/bootstrap.min.css" rel="stylesheet">
</head>
<body>

<div class="container" style="max-width: 600px">
    <div class="py-5 text-center">
        <h2>상품 목록</h2>
    </div>

    <div class="row">
        <div class="col">
            <button class="btn btn-primary float-end"
                    onclick="location.href='addForm.html'"
                    th:onclick="|location.href='@{/basic/items/add}'|"
                    type="button">상품 등록</button>
        </div>
    </div>

    <hr class="my-4">
    <div>
        <table class="table">
            <thead>
            <tr>
                <th>ID</th>
                <th>상품명</th>
                <th>가격</th>
                <th>수량</th>
            </tr>
            </thead>
            <tbody>
            <tr th:each="item : ${items}">
                <td><a href="item.html" th:href="@{/basic/items/{itemId}(itemId=${item.id})}" th:text="${item.id}">회원id</a></td>
                <td><a href="item.html" th:href="@{|/basic/items/${item.id}|}" th:text="${item.itemName}">상품명</a></td>
                <td th:text="${item.price}">10000</td>
                <td th:text="${item.quantity}">10</td>
            </tr>
            </tbody>
        </table>
    </div>

</div> <!-- /container -->

</body>
</html>

spring mvc

Answer 1

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다. 아무개김님.

HTML 파일을 templates 아래에 두고 브라우저에서 직접 파일을 열어서 확인하셨을 때, CSS가 제대로 적용되지 않는 문제는 Thymeleaf와 연관이 있을 수 있습니다. Thymeleaf는 Spring Boot 애플리케이션 내에서 템플릿 파일을 사용해 서버 측에서 데이터를 뷰에 렌더링하는 역할을 합니다. 따라서 로컬 파일 경로를 통해 직접 열 경우, Thymeleaf가 사용되는 맥락이 아니므로 이런 문제가 발생할 수 있습니다.

Spring Boot에서 static 폴더 아래의 정적 리소스들이 웹 애플리케이션의 루트 경로로 공개됩니다. 따라서 href="/css/bootstrap.min.css" 형태로 설정하셔야 정상적으로 적용될 수 있습니다.

다음과 같은 링크들에서 관련된 답변을 확인해보실 수 있습니다:
- CSS 경로 못 찾는 문제
- 템플릿에 CSS 적용문제

이 외에도, 실행 중인 서버에 접속하여 페이지를 확인하셔야 Thymeleaf가 적용되어 동적으로 변환된 페이지를 올바르게 확인할 수 있습니다. 아무개김님께서 서버를 구동시키고 localhost:포트번호/경로 형식으로 파일에 접근하시면, 원하는 결과를 얻으실 수 있을 것입니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

0

rkqkdrn21947

https://inf.run/EX8SW

이거로 해결 봣습니다.

tmplates/css 하위에 css 파일 및 디렉토리 추가하였습니다

servlet과 container에 대한 질문입니다

0

19

1

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

0

61

1

jsp 의존성 수정 요청

0

75

2

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

0

142

1

save() 메서드 문의

0

65

1

request-body-json

0

83

2

MVC 패턴의 적용 단위

0

93

1

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

0

118

2

save 후 결과화면

0

86

2

jsp를 이용한 view

0

97

1

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

0

174

1

수업 코드 제공 관련 문의

0

96

2

RequestMappingHandlerAdapter의 Controller 호출 과정

0

98

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

76

1

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

0

111

1

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

0

73

1

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

0

137

1

html 변경하는 부분 적용 문제

0

100

1

한글 깨짐

0

75

2

메서드 추출에 대해서 궁금한게 있습니다

0

65

1