data:image/s3,"s3://crabby-images/799c3/799c3bd8e764dfe6ee6a3caa2c845386d77628a4" alt="바닐라 JS) 11. 값 입력받기"
1. input과 button 만들기
- input
- HTML에서 사용자로부터 데이터를 입력받기 위해 사용
- type : 입력받을 데이터 형태
text
: 일반 텍스트 입력password
: 비밀번호 입력 (입력된 텍스트가 마스킹됨)email
: 이메일 주소 입력 (브라우저에서 이메일 형식인지 확인)number
: 숫자 입력date
: 날짜 입력checkbox
: 체크박스radio
: 라디오 버튼file
: 파일 업로드submit
: 폼 제출 버튼
- placeholder : 입력 필드가 비어 있을 때 표시되는 텍스트
- button
- 버튼을 만들 때 사용
- type : 버튼을 클릭했을 때 수행할 동작을 정의
button
: 기본 버튼 (JavaScript로 동작을 정의)submit
: 폼 제출 버튼 (폼의 데이터를 제출)reset
: 폼 초기화 버튼 (폼의 모든 입력값을 초기 상태로 되돌림)
- index.html
- input과 button 추가하기
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <link rel="stylesheet" href="style.css"> </head> <body> <input type="text" placeholder="What is your name?" /> <!--사용자로부터 값 입력받기--> <button>로그인</button><!--버튼--> <script src="app.js"></script> </body> </html>
data:image/s3,"s3://crabby-images/1aa2c/1aa2c941fc65a00f6140659a9bb98a4318ee41f4" alt="notion image"
- index.html
- className이나 id 추가하기
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <link rel="stylesheet" href="style.css"> </head> <body> <div class="login-form" id="login-form"> <input type="text" placeholder="What is your name?" /> <!--사용자로부터 값 입력받기--> <button>로그인</button><!--버튼--> <script src="app.js"></script> </div> </body> </html>
2. 요소 가져오기
- app.js
- div 내부를 정의해서 정의된 내부의 요소를 가져오기
const loginForm = document.getElementById("login-form"); // div 내부 가져오기 const loginInut = loginForm.querySelector("input"); // input 태그 가져오기 const loginButton = loginForm.querySelector("button"); // 버튼 가져오기
- 정의된 아이디와 요소를 이용해서 가져오기
const loginInut = document.querySelector("#login-form input"); // input 태그 가져오기 const loginButton = document.querySelector("#login-form button"); // 버튼 가져오기
3. 클릭 이벤트 추가하기
- app.js
const loginInut = document.querySelector("#login-form input"); // input 태그 가져오기 const loginButton = document.querySelector("#login-form button"); // 버튼 가져오기 function handleBtnClick() { console.log("클릭했어요"); } loginButton.addEventListener("click", handleBtnClick);
data:image/s3,"s3://crabby-images/cd587/cd58711e24cb5c4d08f6ca1cdadbe8b6bb9f4a4d" alt="notion image"
4. 입력받은 값 가져오기
- 저장되는 위치 확인하기
- app.js
const loginInut = document.querySelector("#login-form input"); // input 태그 가져오기 const loginButton = document.querySelector("#login-form button"); // 버튼 가져오기 function handleBtnClick() { console.dir(loginInut); console.log("클릭했어요"); } loginButton.addEventListener("click", handleBtnClick);
data:image/s3,"s3://crabby-images/194c2/194c23c84f819e1432bd8bfacc48e5aa62abf5dd" alt="notion image"
data:image/s3,"s3://crabby-images/a3e86/a3e8644d173c828c46a1938cfbb333d26f75b895" alt="notion image"
- index.html의 value값 지정해보기
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <link rel="stylesheet" href="style.css"> </head> <body> <div class="login-form" id="login-form"> <input value="이미 와봤어~" type="text" placeholder="What is your name?" /> <!--사용자로부터 값 입력받기--> <button>로그인</button><!--버튼--> <script src="app.js"></script> </div> </body> </html>
data:image/s3,"s3://crabby-images/27ca2/27ca26dc4b6bbaaba5ef64d1afd8d163b60037c4" alt="notion image"
- dir로 전체를 가져오는 것이 아니라 value 값만 가져오기
- app.js
const loginInut = document.querySelector("#login-form input"); // input 태그 가져오기 const loginButton = document.querySelector("#login-form button"); // 버튼 가져오기 function handleBtnClick() { console.log(loginInut.value); console.log("클릭했어요"); } loginButton.addEventListener("click", handleBtnClick);
data:image/s3,"s3://crabby-images/e26e7/e26e74cba0f39b8ba956d00f72e8ce8b8ffb3e98" alt="notion image"
- 아무것도 입력 안 했을 때는 value 값이 비어있어 확인하는 작업이 필요함
5. 유효성 검사하기
- 입력 받은 값이 없을 때 알려주기
const loginInut = document.querySelector("#login-form input"); // input 태그 가져오기 const loginButton = document.querySelector("#login-form button"); // 버튼 가져오기 function handleBtnClick() { const value = loginInut.value; if(value === ""){ console.log("이름을 입력해주세요~"); } } loginButton.addEventListener("click", handleBtnClick);
data:image/s3,"s3://crabby-images/33576/33576d9346df2616aeab1fdea22a9c8cf23d1f79" alt="notion image"
- 사용자가 볼 수 있게 창 띄우기
const loginInut = document.querySelector("#login-form input"); // input 태그 가져오기 const loginButton = document.querySelector("#login-form button"); // 버튼 가져오기 function handleBtnClick() { const value = loginInut.value; if(value === ""){ alert("이름을 입력해주세요~"); } } loginButton.addEventListener("click", handleBtnClick);
data:image/s3,"s3://crabby-images/30c52/30c529324a57e1f296d6ce4195c40ff45164b901" alt="notion image"
- String의 길이 확인하기
data:image/s3,"s3://crabby-images/a8276/a82768ddcbaf00ddc2a29686d3b11f1b70bcb323" alt="notion image"
- app.js
const loginInut = document.querySelector("#login-form input"); // input 태그 가져오기 const loginButton = document.querySelector("#login-form button"); // 버튼 가져오기 function handleBtnClick() { const username = loginInut.value; if(username === ""){ alert("이름을 입력해주세요~"); } else if(username.length > 15){ // 이름(String)의 길이는 15자 이하여야 함 alert("이름이 너무 길어요ㅜㅠ") } } loginButton.addEventListener("click", handleBtnClick);
- 입력 받은 값 : 안녕 내 이름은 min이야 지금은 아침이야
data:image/s3,"s3://crabby-images/039ab/039ab3a3fa42e8d215ca2c87c313338ff2bc05ad" alt="notion image"
- index.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <link rel="stylesheet" href="style.css"> </head> <body> <div class="login-form" id="login-form"> <input required maxlength="15" type="text" placeholder="What is your name?" /> <!--사용자로부터 값 입력받기--> <button>로그인</button><!--버튼--> <script src="app.js"></script> </div> </body> </html>
- HTML 자체에서 기본적인 것은 제공해주지만 클릭 시 확인 작업을 안하고 있음
- 유효성 검사를 위해 form 태그를 사용해야 함
- form
- HTML에서 사용자가 입력한 데이터를 서버로 전송하기 위한 폼을 정의
- 폼 내부에
<input>
,<textarea>
,<select>
등의 입력 요소를 포함하여 데이터를 수집 method
속성을 통해 데이터를 서버로 전송하는 방식을 정의GET
: 데이터를 URL의 쿼리 문자열로 전송 (기본값)POST
: 데이터를 HTTP 요청의 본문(body)으로 전송action
속성을 통해 데이터를 전송할 서버의 URL 지정- 버튼 없이 enter를 누르거나 click할 때 제출됨
- index.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <link rel="stylesheet" href="style.css"> </head> <body> <form class="login-form" id="login-form"> <input required maxlength="15" type="text" placeholder="What is your name?" /> <!--사용자로부터 값 입력받기--> <button>로그인</button><!--버튼--> <script src="app.js"></script> </form> </body> </html>
const loginInut = document.querySelector("#login-form input"); // input 태그 가져오기 const loginButton = document.querySelector("#login-form button"); // 버튼 가져오기 function handleBtnClick() { const username = loginInut.value; console.log(username); } loginButton.addEventListener("click", handleBtnClick);
data:image/s3,"s3://crabby-images/979dc/979dc22130fd11c1fe7a637bb38a005b40e0537e" alt="notion image"
data:image/s3,"s3://crabby-images/c7622/c762251fa1fe5d4bf62a4a7b8976851c667b48ba" alt="notion image"
<form>
태그는 폼 데이터를 서버로 전송하는 역할- 폼을 제출할 때, 폼 데이터는 URL에 쿼리 문자열(query string) 형태로 붙어서 전송됩
- 기본적으로
form
태그의method
속성이GET
으로 설정
- URL에
?
가 붙고 그 뒤에 쿼리 문자열이 추가 - 각 입력 필드의 이름(name)과 값(value) 쌍으로 구성
- 각 필드의 쌍은
=
로 연결되고, 여러 개의 필드 값은&
로 구분
data:image/s3,"s3://crabby-images/59496/59496e7a197087e08408e9f856fe48f7ab16dbb5" alt="notion image"
6. 새로고침 막기
- 새로고침 : form 태그 submit의 기본 동작
- 버튼 없이 값을 가져오기
const loginForm = document.querySelector("#login-form"); const loginInut = document.querySelector("#login-form input"); // input 태그 가져오기 function onLoginSubmit() { const username = loginInut.value; console.log(username); } loginForm.addEventListener("submit",onLoginSubmit);
- 브라우저가 onLoginSubmit function 호출 및 실행
- 브라우저 내에서 event로부터 정보를 받아서 onLoginSubmit function 실행 버튼을 누르고 있음
- app.js
const loginForm = document.querySelector("#login-form"); const loginInut = document.querySelector("#login-form input"); // input 태그 가져오기 function onLoginSubmit(hi) { hi.preventDefault(); // form 태그 submit의 기본 동작 막기 console.log(hi); } loginForm.addEventListener("submit",onLoginSubmit);
data:image/s3,"s3://crabby-images/e07f6/e07f6e7877b03a559eb0ec1bb9afacff5c634c81" alt="notion image"
- 누군가 form을 submit하면 JS가 function을 호출
- JS가 argument로 발생한 일에 대해 우리가 필요할 만한 정보들을 제공
- 모든 EventListener function의 첫번째 argument는 지금 막 벌어진 일들에 대한 정보
- argument 자리 만들어주기
- app.js
const loginForm = document.querySelector("#login-form"); const loginInut = document.querySelector("#login-form input"); // input 태그 가져오기 function onLoginSubmit(event) { // 자리만 만들어주면 됨 event.preventDefault(); // form 태그 submit의 기본 동작(새로고침) 막기 console.log(loginInut.value); } loginForm.addEventListener("submit",onLoginSubmit);
data:image/s3,"s3://crabby-images/f7520/f75209961157b43ab7d3ad94731450c4953695f3" alt="notion image"
7. Link 이동하기
- a 태그 이용하기
- index.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <link rel="stylesheet" href="style.css"> </head> <body> <form class="login-form" id="login-form"> <input required maxlength="15" type="text" placeholder="What is your name?" /> <!--사용자로부터 값 입력받기--> </form> <a href="https://www.naver.com">Go to Naver</a> <script src="app.js"></script> </body> </html>
data:image/s3,"s3://crabby-images/60748/6074812c7d46fd8310f84111ad352addc6e981ba" alt="notion image"
data:image/s3,"s3://crabby-images/4a588/4a5889791bf1bcd91aa1f8ecaa4d86f05ca21c8a" alt="notion image"
- 기본 설정 막아보기
- app.js
const loginForm = document.querySelector("#login-form"); const loginInut = document.querySelector("#login-form input"); // input 태그 가져오기 const link = document.querySelector("a"); // a태그 가져오기 function handleLinkClick() { alert("클릭했어요!"); } link.addEventListener("click", handleLinkClick);
data:image/s3,"s3://crabby-images/bc3b2/bc3b2ac1994b0777d5fa1ca0761afd7476f804a7" alt="notion image"
data:image/s3,"s3://crabby-images/a3904/a3904ceb1e893f75cea264e3102f0715f77a6c1c" alt="notion image"
const loginForm = document.querySelector("#login-form"); const loginInut = document.querySelector("#login-form input"); // input 태그 가져오기 const link = document.querySelector("a"); // a태그 가져오기 function handleLinkClick(event) { console.log(event); alert("클릭했어요!"); } link.addEventListener("click", handleLinkClick);
data:image/s3,"s3://crabby-images/38621/38621751a6316c66ae9fcfe0e012d6a94a02e78c" alt="notion image"
- 이동 자체를 막기
- app.js
const loginForm = document.querySelector("#login-form"); const loginInut = document.querySelector("#login-form input"); // input 태그 가져오기 const link = document.querySelector("a"); // a태그 가져오기 function handleLinkClick(event) { event.preventDefault(); console.log(event); } link.addEventListener("click", handleLinkClick);
data:image/s3,"s3://crabby-images/84ec0/84ec09118a3252c878bf98bd2b2d030227d90f8a" alt="notion image"
const loginForm = document.querySelector("#login-form"); const loginInut = document.querySelector("#login-form input"); // input 태그 가져오기 const link = document.querySelector("a"); // a태그 가져오기 function handleLinkClick(event) { event.preventDefault(); console.dir(event); } link.addEventListener("click", handleLinkClick);
data:image/s3,"s3://crabby-images/657b1/657b1dcea7bd8a270f28a943667fe27ef2cd9e3c" alt="notion image"
Share article