• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

타임리프 파서 주석 궁금증

23.07.22 18:27 작성 조회수 407

0

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

[질문 내용]
보면 <!--/* ... /--> 이 있고, <!--/*--> ... <!--*/--> 이 있는데, 본문에서는 그냥 한줄표현, 여러줄 표현이라고 하셨는데, 제가 해보니까 그런 차이는 아닌것 같더라구요.

<!--/* ... */--> : 아예 소스 상 주석처리 상태. 그래서 절대경로로 열어도 뷰에는 안나옴

<!--/*--> ... <!--*/--> : 소스상으론 주석처리 안된상태. 그래서 절대경로로 열면 뷰에 보임

이렇게 해석했는데 맞는 내용일까요?

답변 3

·

답변을 작성해보세요.

1

박윤지님의 프로필

박윤지

2023.09.13

  1. <!--/* ... /-->

  2. <!--/*--> ... <!--*/-->

저도 이 부분 헷갈렸어서 이렇게 생각해봤네요

1번 2번 둘다 타임리프에서 렌더링 되지 않는 건 똑같습니다

절대경로로 열었을 시에는 타임리프가 적용 안되기 때문에 html 주석 규칙만 따릅니다
1번은 <!--/* [[${data}]] */--> 예시로 볼 때 <!--와 --> 이라는 html 주석에 /* [[${data}]] */가 싸여있기 때문에 뷰에 안보입니다
2번은 <!--/*--> ... <!--*/--> 예시로 보면, <!--/*-->로 주석이 마감되고, 그 뒤에 ... 코드가 나오기 때문에 이 부분이 뷰에 보이게 됩니다

11 1님의 프로필

11 1

2024.04.10

저도 이렇게 이해했습니다. 파일로 열었을 때 차이가 보이더라고요.

-1

안녕하세요. 우끼기님

강의 메뉴얼을 보시면 다음과 같이 설명을 해두었습니다. 강의 메뉴얼 내용을 다시 참고해주세요.

감사합니다.

 

1. 표준 HTML 주석

<!--
<span th:text="${data}">html data</span>
-->

자바스크립트의 표준 HTML 주석은 타임리프가 렌더링 하지 않고, 그대로 남겨둔다.

2. 타임리프 파서 주석

<!--/* [[${data}]] */-->

<!--/*-->
<span th:text="${data}">html data</span>
<!--*/-->

타임리프 파서 주석은 타임리프의 진짜 주석이다. 렌더링에서 주석 부분을 제거한다.

3. 타임리프 프로토타입 주석

<!--/*/
<span th:text="${data}">html data</span>
/*/-->

타임리프 프로토타입은 약간 특이한데, HTML 주석에 약간의 구문을 더했다.

HTML 파일을 웹 브라우저에서 그대로 열어보면 HTML 주석이기 때문에 이 부분이 웹 브라우저가 렌더링하지 않는다.

타임리프 렌더링을 거치면 이 부분이 정상 렌더링 된다.

쉽게 이야기해서 HTML 파일을 그대로 열어보면 주석처리가 되지만, 타임리프를 렌더링 한 경우에만 보이는 기능이다.

 

-1

인프런 AI 인턴님의 프로필

인프런 AI 인턴

2023.07.24

안녕하세요, 인프런 AI 인턴입니다. 타임리프에서 주석을 작성할 때 주석 처리 방식에 대한 궁금증이 있으신 것 같네요.

주석 처리 방식에는 두 가지가 있는데, <!--/* ... */--><!--/*--> ... <!--*/-->입니다.

<!--/* ... */-->는 전체 소스를 주석 처리하는 방식입니다. 때문에 해당 부분은 뷰에 나타나지 않고, 절대 경로로 열어도 뷰에 표시되지 않습니다.

<!--/*--> ... <!--*/-->는 일부 소스를 주석 처리하는 방식입니다. 이 경우에는 소스 상에서 주석 처리되지 않았기 때문에 뷰에 표시되며, 절대 경로로 열어도 뷰에 표시됩니다.

따라서, 제가 해석한 내용이 맞다고 생각합니다.

추가적인 궁금증이 있으시면 언제든지 물어보세요. 도움이 될 수 있도록 최대한 도와드리겠습니다. 감사합니다.

우끼기님의 프로필

우끼기

질문자

2023.07.24

ai야.. <!--/*--> ... <!--*/--> 는 타임리프 렌더링 후에는 뷰에 안나오고, 타임리프 렌더링이 되지 않은 절대경로 뷰에만 나오는것 아닐까?