type= "button", type="submit"의 차이
5581
작성한 질문수 74
addForm.html에서
<form action="item.html" th:action th:object="${item}" method="post">
<hr class="my-4">
<div class="row">
<div class="col">
<button class="w-100 btn btn-primary btn-lg" type="submit">상품 등록</button>
</div>
<div class="col">
<button class="w-100 btn btn-secondary btn-lg"
onclick="location.href='items.html'"
th:onclick="|location.href='@{/form/items}'|"
type="button">취소</button>
</div>
</div>
</form>상품등록은 type="submit"
취소는 type="button"
을 하셨길래 그 차이가 궁금하여 구글링을 해봤더니 버튼은 타입 명시가 없다면 기본적으로 'submit' 처리가 되며 'submit'은 새로고침을 하게 한다. 라는 것을 알게되었습니다.
그래도 잘 이해가 안되 상품등록버튼을 type="button"
으로 바꿔봤더니 작동이 되지않았습니다...
<기존코드>
<button class="w-100 btn btn-primary btn-lg" type="submit">상품 등록</button><변경 코드>
<button class="w-100 btn btn-primary btn-lg" type="button">상품 등록</button>그래서 개발자도구를 보니 type="button"을 하면 POST가 아닌 GET으로만 보내고 있는 것을 확인했습니다.
<정리>
form 속성 중 method가 post인데 상품등록버튼을type="submit"에서 type="button"으로 바꾸면 POST가 GET으로 바뀌는 이유가 궁금합니다.
답변 1
0
안녕하세요, 코딩먹는하마 님! 공식 서포터즈 codesweaver 입니다.
Button 태그의 동작에 대한 질문이군요.
Button은 Form 내부에 있을 때 의미가 달라지므로 주의해야 합니다. 말씀하신것처럼 Button의 타입 속성을 생략하면 기본적으로 Submit 으로 작동합니다.
Form 밖에서 Submit은 아무 의미도 없으므로(전송할 폼이 없으므로) 아무 변화도 일어나지 않습니다. Form 내부에서는 자신이 속한 Form 을 서버에 전송합니다. 그래서 화면이 번쩍이면서 새로 고침이 발생하죠. 그래서 Form 내부에서 순수하게 버튼으로 동작하게 하려면 type 속성을 'button'으로 설정해야 합니다. 버튼은 순수하게 UI요소인 버튼이 됩니다.
다만 지금 코드를 보시면 onclick="" 으로 버튼을 클릭했을 때 자바스크립트 이벤트가 발생하도록 설정하였습니다. 그리고 그 코든내용은 페이지 이동입니다(location.href). 그래서 버튼을 눌렀을 때 화면이 깜빡이며 새로고침이 되는것 처럼 보이지요.
감사합니다.
servlet과 container에 대한 질문입니다
0
25
1
api를 어느 컨트롤러에 작성해야하는지는 어떤 기준으로 해야하나요?
0
64
1
jsp 의존성 수정 요청
0
80
2
요즘 웹 서버가 주로 사용되는 이유는 SPA 구조 때문일까요 ?
0
143
1
save() 메서드 문의
0
67
1
절대 경로로 templates/basic 하위 파일 열면 css 적용 안되는 현상
0
101
1
request-body-json
0
83
2
MVC 패턴의 적용 단위
0
97
1
RequestMapping을 이용한 핸들러, 어댑터
0
119
2
save 후 결과화면
0
89
2
jsp를 이용한 view
0
97
1
application.properties에 debug 추가해도 결과가 똑같습니다.
0
178
1
수업 코드 제공 관련 문의
0
97
2
RequestMappingHandlerAdapter의 Controller 호출 과정
0
100
3
파일 오픈 시
0
70
1
스프링 배치 관련
0
78
1
@RequestParam의 defaultValue가 blank 값도 처리하는 지 여부
0
112
1
postman으로 /request-body-json-v1 호출시 500 error
0
96
1
프론트엔드와 백엔드의 mvc, rest api에 대한 질문
0
79
1
모델의 역할과 계층 분리에 대한 이해 차이 + 추가질문
0
111
1
console log 출력 관련 질문입니다.
0
75
1
애플리케이션이 실행 되지 않습니다 ㅠㅠㅠ
0
139
1
html 변경하는 부분 적용 문제
0
103
1
한글 깨짐
0
77
2





