반응형
App.js
import React from "react";
import Hello from "./Hello.js";
import "./App.css";
import Wrapper from "./Wrapper.js";
import Counter from "./Counter.js";
import InputSample from "./InputSample.js";
function App() {
return <InputSample />;
}
export default App;
InputSample.js
import React, { useState, useRef } from "react";
function InputSample() {
const [inputs, setInputs] = useState({
name: "",
nickname: ""
});
const nameInput = useRef();
const { name, nickname } = inputs;
const onChange = e => {
const { name, value } = e.target;
//객체 상태를 업데이트 할때에는 객체를 복사하고 나서 덮어씌우고 업데이트 해줘야 한다.
setInputs({
...inputs,
[name]: value
});
};
const onReset = () => {
setInputs({
name: "",
nickname: ""
});
nameInput.current.focus();
};
return (
<div>
<input name="name" onChange={onChange} placeholder="이름" value={name} />
<input
name="nickname"
placeholder="닉네임"
onChange={onChange}
value={nickname}
ref={nameInput}
/>
<button onClick={onReset}>초기화</button>
<div>
<b>값: 닉네임</b>
{name} ({nickname})
</div>
</div>
);
}
export default InputSample;
반응형
'2020 > React' 카테고리의 다른 글
React 새로운 배열 추가하기 (0) | 2020.03.31 |
---|---|
React 배열 렌더링하기 (0) | 2020.03.31 |
InputSample (0) | 2020.03.30 |
Counter 만들기 useState (0) | 2020.03.30 |
React 조건부 렌더링 (0) | 2020.03.30 |