inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

상품 목록 - 타임리프

리터럴 대체 문법과 링크 표현식에 대한 차이점이 무엇인가요?

해결된 질문

417

컴퓨터공부하자

작성한 질문수 54

0

안녕하세요 강의 잘 보고있습니다.

설명을 정말 잘해주셔서 명강의라고 생각합니다! 

그런데 궁금한 점이 생겨 질문을 올리게 되었습니다. 

제가 실험삼아 

A: th:href="@{/basic/items/{itemId}(itemId=${item.id})}"

B: th:href="|/basic/items/{itemId}(itemId=${item.id})|"

C: th:href="@{/basic/items/${item.id}}"

D: th:href="|/basic/items/${item.id}|"

A부분을 B, C, D로 고쳐서 실행했더니 잘 실행되었습니다.

 @{...} 이것과 |...| 이것 모두 문자와 표현식을 더하기 없이 사용할 수 있다는 장점이 있습니다. 그런데 차이점을 솔직히 잘 모르겠습니다. 

@{...} 이 문법과 |...| 이 문법이 구분되어져 있는 이유가 있을까요? 

MVC spring

답변 1

4

David

안녕하세요. 컴퓨터공부하자님, 공식 서포터즈 Taewon David Hwang입니다.

@{...} 문법은 Link(urls) 표현을 위한 문법이고

|...| 문법은 템플릿 문자열을 위한 문법입니다.

.

a태그 href속성 값의 조건은 링크를 나타내는 문자열입니다. 따라서 링크 표현 문법인 @{...} 사용하지 않고 템플릿 문자열을 통해 링크를 나타내는 문자열(/basic/items/1)을 href 속성의 값으로 제공한다면 동일하게 동작합니다.

.

타임리프의 링크 표현 문법은 링크를 문자열로 제공하는 것 이외에도 다양한 기능을 지원합니다.

템플릿 문자열 문법은 문자열을 구성하는데 편리함을 제공합니다.

즉, 두 문법이 제공하고자 하는 기능의 목적이 다릅니다. 그 목적과 별개로 href 속성 값으로 문자열을 제공할 수 있는 일을 할 수 있는 것이죠.

.

템플릿 문자열은 다음과 같이 문자열 구성에 편리함을 제공합니다. 중간에 변수를 넣어 문자열을 구성하기 위해서 쌍따옴표와 문자열을 더해주는 연산자를 사용할 필요가 없는 것이죠.

예시)

String welcomeComment = "안녕하세요, " + userName + "님." + accessCount + "번째 방문을 환영합니다."

String welcomeComment = `안녕하세요 {userName}님. {accessCount}번째 방문을 환영합니다.`

.
감사합니다.

* 참고

2.4 Link Expressions https://www.thymeleaf.org/doc/articles/standarddialect5minutes.html

Link Urls https://www.thymeleaf.org/doc/tutorials/2.1/usingthymeleaf.html#link-urls

Literal substitutions https://www.thymeleaf.org/doc/tutorials/2.1/usingthymeleaf.html#literal-substitutions

servlet과 container에 대한 질문입니다

0

29

1

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

0

65

1

jsp 의존성 수정 요청

0

82

2

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

0

145

1

save() 메서드 문의

0

67

1

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

0

102

1

request-body-json

0

84

2

MVC 패턴의 적용 단위

0

97

1

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

0

120

2

save 후 결과화면

0

91

2

jsp를 이용한 view

0

98

1

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

0

181

1

수업 코드 제공 관련 문의

0

98

2

RequestMappingHandlerAdapter의 Controller 호출 과정

0

102

3

파일 오픈 시

0

70

1

스프링 배치 관련

0

78

1

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

0

114

1

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

0

96

1

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

0

82

1

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

0

113

1

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

0

75

1

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

0

140

1

html 변경하는 부분 적용 문제

0

103

1

한글 깨짐

0

77

2