inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 MVC 1편 - 백엔드 웹 개발 핵심 기술

PRG Post/Redirect/Get

type= "button", type="submit"의 차이

5581

코딩먹는하마

작성한 질문수 74

0

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으로 바뀌는 이유가 궁금합니다.

spring mvc

답변 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