• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    해결됨

thymeleaf client side redirection 질문

24.01.16 12:29 작성 조회수 135

0

안녕하세요 강의 듣다가 좀 헷갈리는게 있어 질문 올려요

<button class="w-100 btn btn-secondary btn-lg"
        th:onclick="|location.href='@{/form/items}'|"
        type="button">취소</button>

여기서 onclick은 서버한테 해당 url로의 새 http request message 를 보내지 않는 그냥 client 쪽에서 온전히 redirection 하는 거라고 들었는데요, 이러면 client는 해당 URL의 view를 어떻게 찾아내나요?

 

원래는 새 url로 이동하려면 해당 url로 request 보내고 서버로부터 완성된 VIEW를 받아서 보여주는거잖아요?

근데 얘는 thymeleaf로 되어있어서 서버로부터 데이터도 껴넣어져야되는데 어떻게 온전히 client가 알아서 view를 찾아낼 수 있다는건지 이해가 안갑니다

답변 2

·

답변을 작성해보세요.

0

안녕하세요. mintuchel님

AI 인턴이 답을 잘 해주었는데요.

다음 내용을 참고해주세요.

location.href를 사용할 때, 클라이언트 측에서는 JavaScript를 통해 새로운 URL을 브라우저의 주소창에 설정하고, 그 URL로 페이지를 새로 로드합니다. 이때 실제로 새로운 리소스를 요청하는 것이기 때문에 서버에서 뷰를 찾아 응답하는 과정이 다시 이루어집니다. 따라서 클라이언트가 독립적으로 뷰를 찾는 것이 아니라, 서버에 새로운 HTTP 요청을 보내 뷰를 요청하는 것입니다.

감사합니다.

0

인프런 AI 인턴님의 프로필

인프런 AI 인턴

2024.01.16

안녕하세요, 인프런 AI 인턴입니다.

mintuchel님의 질문은 Thymeleaf 템플릿 엔진을 사용할 때 th:onclick 속성을 통해 클라이언트 측 리다이렉션을 할 때, 클라이언트가 어떻게 해당 URL의 뷰를 찾아내는지에 대한 이해와 관련된 내용 같습니다.

Thymeleaf를 사용할 때 th:onclick 구문 내에 쓰이는 @{...} (링크 URL 표현식)은 서버 측에서 렌더링 될 때 해당 애플리케이션의 컨텍스트 패스를 포함한 적절한 URL로 변환됩니다. 즉, 이 구문은 서버에서 HTML 페이지를 생성할 때 실제 컨텍스트 경로에 맞게 URL을 조정해줍니다.

location.href를 사용할 때, 클라이언트 측에서는 JavaScript를 통해 새로운 URL을 브라우저의 주소창에 설정하고, 그 URL로 페이지를 새로 로드합니다. 이때 실제로 새로운 리소스를 요청하는 것이기 때문에 서버에서 뷰를 찾아 응답하는 과정이 다시 이루어집니다. 따라서 클라이언트가 독립적으로 뷰를 찾는 것이 아니라, 서버에 새로운 HTTP 요청을 보내 뷰를 요청하는 것입니다.

이쪽 내용과 관련해서는 아래의 링크에서 비슷한 질문의 답변을 찾을 수 있습니다:

두 링크 모두 Thymeleaf의 링크 표현식과 리터럴 표현에 대한 이해를 돕는 답변이 담겨 있기 때문에, mintuchel님의 궁금증을 해소하는 데 도움이 될 것입니다.

강의 내용과 답변을 통해 클라이언트 측 JavaScript에서 location.href를 사용하는 것과 서버 측 URL 매핑, 그리고 Thymeleaf의 URL 표현식의 차이점을 좀 더 명확하게 이해하실 수 있기를 바랍니다.

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