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

냐암2님의 프로필 이미지
냐암2

작성한 질문수

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

체크 박스 - 단일1

value의 값

작성

·

6

0


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

[질문 내용]
여기에 질문 내용을 남겨주세요.

판매 여부를 체크하지 않았는데, 크롬 '소스보기'에서 확인해보면

<input type="checkbox" id="open" class="form-check" name="open" value="true"><input type="hidden" name="_open" value="on"/>

과 같이 value="true"가 나옵니다.

 

 

value의 값이 true이면 타임리프 속성(th:field를 사용하면, 값이 true인 경우 체크를 자동으로 처리)으로 체크가 되어야 하는 것과도 좀 충돌하는 것 같습니다.

체크를 하지 않았는데 value의 값은 true이고, 정작 타임리프는 true일 경우 자동으로 체크처리해야하는데 화면에는 체크처리가 되지 않아있고...

 

어디서 잘못 생각한 것일까요?

 

답변 1

0

안녕하세요, 인프런 AI 인턴입니다. 냐암2님.

해당 질문은 타임리프에서 th:field를 사용할 때 체크박스의 동작에 대한 것으로 보여집니다. 타임리프는 th:field를 사용하여 체크박스를 렌더링할 때, 값이 true인 경우에만 체크 상태를 화면에 나타내게 됩니다. 하지만 여기서는 value 속성의 “true”가 체크박스의 체크 상태와는 직접적인 연관이 없습니다.

관련된 기존 질문과 답변들을 찾아보았고, 아래 링크들을 통해 더 깊이 있는 설명을 얻으실 수 있을 것입니다:

  1. 페이지 소스보기에서 true 값 질문 - Checkbox의 value와 checked 상태에 관한 설명.
  2. th:field="*{open}"에 의해 생성된 value 속성 관련 - th:field로 인해 자동 생성되는 value 속성에 대한 해설.

기본적으로, 클라이언트(브라우저) 측에서 HTML을 생성할 때 value=“true”는 체크박스가 선택될 경우 서버로 전송할 값을 의미합니다. 그래서 실제 체크 상태와는 무관하게 항상 “true”로 표시될 수 있습니다. 체크 상태는 서버로 전송된 데이터로 결정되며, 전송된 데이터가 없는 경우 _open과 같은 히든 필드에 의하여 unchecked 상태로 간주됩니다.

이 점이 혼동을 일으키는 것 같습니다. 타임리프에서는 th:field가 객체의 값을 기준으로 checked 상태를 결정하므로 객체의 해당 필드가 true일 때만 체크 상태로 렌더링 됩니다.

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

냐암2님의 프로필 이미지
냐암2

작성한 질문수

질문하기