타임리프 - 체크 박스 코드 추가

<!-- single checkbox -->
<div>판매 여부</div>
<div><div class="form-check">
<input type="checkbox" id="open" th:field="*{open}" class="form-checkinput">
<label for="open" class="form-check-label">판매 오픈</label>
</div>
</div>

 

 

타임리프 체크 박스 HTML 생성 결과

<!-- single checkbox -->
<div>판매 여부</div>
<div>
<div class="form-check">
<input type="checkbox" id="open" class="form-check-input" name="open"
value="true">
<input type="hidden" name="_open" value="on"/>
<label for="open" class="form-check-label">판매 오픈</label>
</div>
</div>

 

 

<input type="hidden" name="_open" value="on"/>


타임리프를 사용하면 체크 박스의 히든 필드와 관련된 부분도 함께 해결해준다. HTML 생성 결과를 보면
히든 필드 부분이 자동으로 생성되어 있다
.

 

 

 

실행 로그

 

FormItemController : item.open=true //체크 박스를 선택하는 경우
FormItemController : item.open=false //체크 박스를 선택하지 않는 경우

 

 

상품 상세에 적용하자.


item.html

<hr class="my-4">
<!-- single checkbox -->
<div>판매 여부</div>
<div>
<div class="form-check">
<input type="checkbox" id="open" th:field="${item.open}" class="formcheck-input" disabled>
<label for="open" class="form-check-label">판매 오픈</label>
</div>
</div>

주의: item.html 에는 th:object 를 사용하지 않았기 때문에 th:field 부분에 ${item.open} 으로
적어주어야 한다
.
disabled 를 사용해서 상품 상세에서는 체크 박스가 선택되지 않도록 했다.

 

 

HTML 생성 결과

<hr class="my-4">
<!-- single checkbox -->
<div class="form-check">
<input type="checkbox" id="open" class="form-check-input" disabled name="open" value="true"
checked="checked">
<label for="open" class="form-check-label">판매 오픈</label>
</div>

 

타임리프의 체크 확인

 

checked="checked"


체크 박스에서 판매 여부를 선택해서 저장하면, 조회시에 checked 속성이 추가된 것을 확인할 수 있다.
이런 부분을 개발자가 직접 처리하려면 상당히 번거롭다. 타임리프의 th:field 를 사용하면, 값이 true
인 경우 체크를 자동으로 처리해준다

 

 

상품 수정에도 적용하자.


editForm.html

<hr class="my-4">
<!-- single checkbox -->
<div>판매 여부</div>
<div>
<div class="form-check">
<input type="checkbox" id="open" th:field="*{open}" class="form-checkinput">
<label for="open" class="form-check-label">판매 오픈</label>
</div>
</div>
...

상품 수정도 th:object , th:field 를 모두 적용해야 한다.
실행해보면 체크 박스를 수정해도 반영되지 않는다. 실제 반영되도록 다음 코드를 수정하자.

 

 

ItemRepository - update() 코드를 다음과 같이 수정하자


public void update(Long itemId, Item updateParam) {

Item findItem = findById(itemId);

findItem.setItemName(updateParam.getItemName());
findItem.setPrice(updateParam.getPrice());
findItem.setQuantity(updateParam.getQuantity());
findItem.setOpen(updateParam.getOpen());
findItem.setRegions(updateParam.getRegions());
findItem.setItemType(updateParam.getItemType());
findItem.setDeliveryCode(updateParam.getDeliveryCode());
}


open
이외에 나머지 필드도 업데이트 되도록 미리 넣어두자

 

 

 

 

출처 : 김영한 MVC2 강의

'Spring > Thymeleaf' 카테고리의 다른 글

Thymeleaf - 체크 박스 - 멀티  (0) 2022.09.07
Thymeleaf - 체크 박스 - 단일1  (0) 2022.09.07
Thymeleaf - 입력 폼 처리  (0) 2022.09.07
Thymeleaf - 템플릿 레이아웃2  (0) 2022.09.05
Thymeleaf - 템플릿 레이아웃1  (0) 2022.09.04
복사했습니다!