인프런 커뮤니티 질문&답변

유요한님의 프로필 이미지

작성한 질문수

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

HTML, HTTP API, CSR, SSR

백엔드 개발자로서 프론트에 대해서 질문

23.04.20 22:57 작성

·

1.1K

·

수정됨

1

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

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

[질문 내용]
리액트는 선택이고 타임리프는 알아야 한다고 하셨는데 제가 알기로는 요즘에는 REST 방식으로 JSON 형태로 주고 받고 요즘 자주 쓰는 React 같은 경우는 서버를 아예 따로 띄어주고 JSON으로 데이터만 주고 받고 하는데 타임리프를 꼭 자세히 알아야 하나요?

여기서 말하는 자세히란 지금 현재 타임리프 문법은 대략적으로 알 고 있고 타임리프로 프론트가 작성되어 있는거 보면 알 수 있을 정도는 되는데 프론트를 혼자서 만들 정도는 안됩니다. (그게 맞지 않아서 백엔드를 선택했는데...)

프로젝트 만드는데 타임리프로도 만들어야 할 정도로 알아야 하는지 궁금합니다. 현재 계획으로는 리액트하고 백엔드하고 나눠서 따로 서버 배포하고 백엔드는 REST 방식으로만 진행해서 MVC에서 View를 빼서 나누려고 하는데 타임리프로 알아야 한다면 이것도 프로젝트로 만들어야할지 고민이되서 질문드립니다.

답변 2

3

y2gcoder님의 프로필 이미지

2023. 04. 21. 09:59

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

타임리프를 꼭 자세히 알아야 하는지는 프로젝트의 요구사항과 개발 팀의 기술 스택에 따라 다릅니다. 현재의 계획에 따르면, 프론트엔드와 백엔드를 분리하여 각각 리액트와 REST 방식을 사용하려고 하는 것으로 보입니다. 이러한 경우에는 타임리프를 깊게 알아야 할 필요가 없을 수도 있습니다.

그러나, 여러 가지 이유로 타임리프를 사용해야 하는 상황이 생길 수 있습니다. 예를 들어, 기존의 프로젝트가 타임리프를 사용하고 있거나, 팀 내에서 타임리프를 선호하는 경우입니다. 이 경우에는 타임리프에 대한 지식이 필요하게 됩니다. 저 또한 JSP를 사용한 SSR 방식의 개발을 선호하던 회사에 다녔던 적이 있습니다. 해당 회사에서 신규 프로젝트를 맡았고, 해당 프로젝트 또한 SSR 방식으로 개발해야 했습니다. 이 때 저는 React, Thymeleaf를 사용할 수 있었고, JSP를 스프링에서 권장하지 않는다고 알고 있었습니다. 또한 팀원들도 JSP를 사용한 개발에 익숙했습니다. 그래서 스프링에서 권장하고 JSP를 사용한 개발 방식과 비슷한 Thymeleaf를 써보자고 제안할 수 있었고, 신규 프로젝트를 Thymeleaf를 사용해서 출시까지 할 수 있었습니다.

또한, 다양한 기술 스택에 대한 지식은 개발자로서 가치를 높이는 요소 중 하나입니다. 타임리프를 포함하여 다양한 라이브러리와 프레임워크에 대한 경험이 있으면, 더 많은 프로젝트와 팀에서 요구되는 기술 요구사항에 부응할 수 있습니다.

결론적으로, 타임리프를 깊게 알아야 할지 여부는 프로젝트와 팀의 상황에 따라 다릅니다. 하지만 다양한 기술에 대한 지식과 경험은 개발자의 역량을 향상시키는 중요한 요소입니다. 이에 따라 타임리프를 좀 더 공부하고 프로젝트에 적용해 볼 여지가 있다면, 시도해 보는 것도 좋은 선택일 수 있습니다.

감사합니다.

0

문희찬님의 프로필 이미지

2023. 04. 21. 09:15

저도 궁금해요