inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 MVC 2편 - 백엔드 웹 개발 활용 기술

체크 박스 - 멀티

th:for="${#ids.prev('regions')}"

622

계란

작성한 질문수 17

0

해당 th:for="${#ids.prev('regions')}" 구문을 사용해서

regions에 대한 id값을 자동으로 할당받지 않아도

즉 th:for="${#ids.prev('regions')}" 구문을 빼는것을 얘기합니다.

소스보기를 하니 자동으로 regions 1,2,3 아이디값이 들어있는데

이 경우에는 thymeleaf가 th:for="${#ids.prev('regions')}"를 사용하지 않아도 th:for="${#ids.prev('regions')}" 를 사용한것처럼 자동으로 인식해서 만들어줬다고 봐야할까요 ?

spring mvc

답변 2

3

김영한

안녕하세요. sk47kt님

주어진 코드에서 th:field="*{regions}"를 사용하면 타임리프는 해당 필드에 대한 idname을 자동으로 생성합니다. 만약 이 부분이 반복되면 (예: 리스트나 배열의 경우), 인덱스 값 (0, 1, 2, ...)이 추가되어 id와 name이 생성됩니다.

따라서 주어진 설명대로 소스보기를 했을 때 regions1, regions2, regions3과 같은 형태의 id 값이 생성된 것이라면, 이는 th:field="*{regions}" 속성 때문입니다.

th:for="${#ids.prev('regions')}" 구문 없이도 id 값이 자동으로 생성되는 것은 맞으며, 이것은 th:field 속성의 작동 방식 때문입니다.

#ids.prev('regions')를 사용한 이유는 label에서 for 속성에 input의 id 속성과 맞추기 위해서 입니다.

이것을 맞추어 두어야 label을 선택했을 때, 그러니까 글자를 선택했을 때도 input 요소가 선택되기 때문입니다.

도움이 되셨길 바래요.

감사합니다.

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴이에요. th:for=”\({#ids.prev('regions')}" 구문을 사용하여 regions에 대한 id값을 자동으로 할당받지 않으려면 해당 구문을 빼면 됩니다. 하지만 소스를 확인해보니 regions에 자동으로 id 값이 할당되어 있는 것으로 보입니다. 이 경우에는 thymeleaf가 th:for="\){#ids.prev(‘regions’)}“를 사용하지 않아도 자동으로 인식하여 id 값을 만들어 준 것으로 보입니다. 이는 thymeleaf의 기능 중 하나인 자동 id 할당 기능입니다. 이 기능을 사용해서 자동으로 id 값을 할당받을 수 있습니다. 질문이 있으시면 더 답변해드릴게요. 감사합니다.

이미지 업로드와 db 트랜잭션 묶는법

0

41

1

Could not resolve org.springframework.boot:spring-boot-starter-validation:2.4.4

0

50

2

MessageSourceTest 코드

0

46

1

인터셉터 에러 설정

0

48

1

resolveArgument()메서드 질문

0

55

1

43강 검증1 에서 실패 로직 관련 질문있습니다.

0

53

2

타임리프 3.X 버전 rendering, serializer 에러 해결 방법

2

132

3

스프링 빈에 등록이 안되는거 같은데 어떻게 하면 좋을까요?ㅠㅠ

0

87

3

pdf 오타 문의

0

56

1

ItemUpdateForm 검증 관련 질문입니다.

0

47

1

22page 링크 주소 변경

0

58

2

특정 데이터와 파일을 함께 저장 시, 테이블 구조 질문

0

52

1

섹션3번 수업에 대한 질문입니다.

0

79

2

@Autowired 보다 더 좋은 방법이 어떤 걸까요?

0

84

2

타입컨버터 가 람다랑 비슷해 보이는데 저의 생각이 맞는지?.

0

64

1

자바스크립트 인라인에서 객체 직렬화 시 오류가 납니다

0

141

3

스프링부트 - 오류페이지2 에서 500.html 에서 쓰인 객체 질문

0

63

1

톰캣 에러 페이지가 안보입니다.

0

100

2

apiEceptionController에서 센드 에러 호출하면 안되는지?

0

80

1

세션 타임아웃시 쿠키 삭제 방법이 없나요?

0

118

2

ApiExceptionController 질문드립니다.

0

62

1

셀렉박스 챕터에서 option value에 ==배송 방식 선택== 이것을 넣은 이유가 궁금함, 이렇게 구상해도 되는지?

0

64

1

MemberRepository 필드의 fianl 선언 유무

0

84

2

혹시 index.html 에서는 fragment 사용이 안되는건가요

0

57

1