작성
·
501
·
수정됨
0
@GetMapping("/formatter/edit")
public String formatterForm(Model model){
Form form = new Form();
form.setNumber(10000);
form.setLocalDateTime(LocalDateTime.now());
log.info("form={}",form);
model.addAttribute("form",form);
return "formatter-form";
}
@PostMapping("/formatter/edit")
public String formatterEdit(@ModelAttribute Form form){
log.info("post form={}",form);
return "formatter-view";
}
로그를 통해 form, post form을 출력해보았습니다.
저는 처음 form은 그냥 입력한 값이 나오고 그다음 post form은 ModelAttribute에 들어갈 때
public String formatterEdit(@ModelAttribute Form form){
포멧터가 form의 타입을 변경하고 입력한다고 예상했습니다.
하지만 로그를 보니
form=FormatterController.Form(number=10000, localDateTime=2023-04-23T12:39:53.251212)
post form=FormatterController.Form(number=10000, localDateTime=2023-04-23T12:39:53)
값은 값이 나오는 것을 확인했습니다.
제가 생각했을 때는 Argument Resolver 안에 ConversionService 안에 Formatter 가 controller를 호출하기 전 @ModelAttribute에 입력할 때 실행되지만
@Data
static class Form{
@NumberFormat(pattern = "###,###")
private Integer number;
@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private LocalDateTime localDateTime;
}
에서 @NumberFormat(pattern = "###,###") 패턴이 적용 되는 시점은 html에서
"${{form.number}}"
중괄호2개가 있을 때다. 그래서 로그는 값은 같은 값이 출력이 되지만 html에서는 다른 값이 출력된다. 라고 이해를 했는 데 맞게 생각한 것인지 궁금합니다.
답변주시면 정말 감사하겠습니다.
답변 1
0
안녕하세요. 코딩먹는하마님, 공식 서포터즈 David입니다.
thymeleaf에서 html파일을 렌더링할 때 formatter가 호출되어 정해진 패턴을 따라 데이터를 문자열로 출력하게 됩니다.
아래 라인에 브레이크 포인트를 걸고 디버깅 해보시면 이 과정을 자세히 확인하실 수 있습니다.
감사합니다.