728x90
1. input 상태 관리하기(input이 한 개일 때)
1) App,js
import React from 'react';
import InputSample from './InputSample';
function App() {
return (
<InputSample />
);
}
export default App;
2) InputSample.js
input 태그의 value 값도 설정해주는 것이 중요.
그렇게 해야, 상태가 바뀌었을때 input 의 내용도 업데이트 됨
import React, { useState } from 'react';
function InputSample() {
const [text, setText] = useState('');
const onChange = (e) => {
setText(e.target.value);
};
const onReset = () => {
setText('');
};
return (
<div>
<input onChange={onChange} value={text} />
<button onClick={onReset}>초기화</button>
<div>
<b>값: {text}</b>
</div>
</div>
);
}
export default InputSample;
2. input 상태 관리하기(input이 한 개 이상일 때)
1) App,js
import React from 'react';
import InputSample from './InputSample';
function App() {
return (
<InputSample />
);
}
2) inputSample.js
import React, { useState } from 'react';
function InputSample() {
const [inputs, setInputs] = useState({
name: '',
nickname: ''
});
const { name, nickname } = inputs; // 비구조화 할당을 통해 값 추출
const onChange = (e) => {
const { value, name } = e.target; // 우선 e.target 에서 name 과 value 를 추출
// = console.log(e.target.name);(name과 nickname)
// = console.log(e.target.value);(name과 nickname의 값)
//리액트에서 객체 업데이트 하기 위해서는 기존에 객체 복사 해야한다
setInputs({
...inputs, // 기존의 input 객체를 복사한 뒤
[name]: value // name 키를 가진 값을 value 로 설정
});
};
const onReset = () => {
setInputs({
name: '',
nickname: '',
})
};
return (
<div>
<input name="name" placeholder="이름" onChange={onChange} value={name} />
<input name="nickname" placeholder="닉네임" onChange={onChange} value={nickname}/>
<button onClick={onReset}>초기화</button>
<div>
<b>값: </b>
{name} ({nickname})
</div>
</div>
);
}
export default InputSample;
728x90
'FRONT' 카테고리의 다른 글
[React] 배열 렌더링 하기 (0) | 2023.07.18 |
---|---|
[React] useRef 로 특정 DOM 선택하기 (0) | 2023.07.17 |
[React] useState를 통해 컴포넌트에서 바뀌는 값 관리 (클릭 이벤트) (0) | 2023.07.17 |
[React] 조건부 렌더링 (0) | 2023.07.17 |
[React] props를 통해 컴포넌트에게 값 전달하는 법 (0) | 2023.07.17 |