Front-end/React
[React] <input /> 태그
늘이
2023. 6. 29. 14:15
1. 입력을 받을 수 있는 박스 생성 방법들
<input type="text"/>
<input type="range"/>
<input type="date"/>
<input type="number"/>
<textarea></textarea>
<select></select>
2. <input/>에 입력 시 코드 실행하기
onChange/onInput 등 이벤트 핸들러 사용(필요 시 검색)
3. <input>에 입력한 값 가져오기
이벤트 핸들러에 들어가는 함수에 파라미터 e 추가하기
<input onChange={(e) => {console.log(e)}} />
e는 이벤트 객체, 현재 발생하는 이벤트와 관련한 기능을 제공하는 일종의 변수(e라는 이름 사용안해도 됨)
이벤트가 발생한 html 태그: e.target
<input onChange={(e) => {console.log(e.target)}} />
이벤트에 발생한 html 태그에 입력한 값: e.target.value
<input onChange={(e) => {console.log(e.target.value)}} />
이벤트 버블링 막기: e.stopPropagation()
<input onChange={(e) => {console.log(e.target.value)}} />
이벤트 버블링: 클릭 이벤트 시 상위 html로 퍼지는 현상 |
4. <input>에 입력한 값 저장하기
보통 변수/state에 e.target.value를 저장해둠
function App (){
let [입력값, 입력값변경] = useState('');
return (
<input onChange={(e)=>{
입력값변경(e.target.value)
console.log(입력값)
}} />
)
}
cf) state 변경함수는 약간 늦게 처리됨 -> async(비동기적처리) |