일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- GDI
- ClickOnce
- crashlog
- M8200
- php
- JavaScript
- API
- 블루투스 헤드셋
- C/C++
- VS2008
- MFC
- 크래시로그
- EUC-KR
- docker
- 자바스크립트
- .net
- 데이터 전달
- Font
- protobuf-c
- self-signed ssl
- net
- PDA
- C#
- 한 번만 실행
- 기념일관리
- 와이브로
- plcrashreporter
- phpmailer
- 설치제거
- Antialiasing
- Today
- Total
~☆~ 우하하!!~ 개발블로그
React - 컴포넌트에 값 저장하기 본문
이번 포스트는 https://iwoohaha.tistory.com/316 의 연장이다.
지난번 포스트에서는 버튼을 클릭하면 단순히 알럿 메시지를 표시하는 정도의 수정이었는데, 이번에는 버튼이 도대체 몇 번이나 클릭을 당했는지를 표시해보려고 한다.
컴포넌트에서 어떤 값을 관리하기 위해서는 상태(state)를 관리해야 하는데, 'react' 로부터 useState 를 import 하는 것으로부터 시작한다.
import { useState } from 'react';
node_modules 디렉토리 아래의 react 에서 export 하고 있는 컴포넌트가 무수히 많기 때문에 그 중에서 필요한 useState 만을 가져오기 위한 방법으로 { } 괄호 사이에 useState 를 사용하고 있는 것이다.
이렇게 상태관리를 위한 컴포넌트 useState 를 import 하고 나면 아래와 같이 상태관리용 변수와 상태값 변경용 함수를 선언할 수 있다.
const [count, setCount] = useState(0);
useState 에 추가한 값은 count 의 초깃값이다.
이렇게 상태가 관리되면, 상태값이 변경될 때마다 자동으로 렌더링이 발생하여 UI 가 업데이트된다.
완성된 코드는 다음과 같다.
import { useState } from 'react';
function MyButton() {
const [count, setCount] = useState(0);
function handleClick() {
//alert('You clicked me!');
setCount(count + 1);
}
return (
<button onClick={handleClick}>I'm clicked {count} times!</button>
)
}
export default MyButton;
실행한 상태에서 각 버튼을 몇 번씩 클릭해봤다.
MyButton 이라는 컴포넌트에서 상태를 관리한다면, 여러 개의 컴포넌트간의 그 상태값은 분리되어 관리될 수 있다.
반면, 4개의 버튼 컴포넌트가 어느 상태값을 공유하길 원한다면, MyButton 컴포넌트에서 상태를 관리하지 말고 그 상위인 MyApp 컴포넌트에서 상태를 관리하도록 변경해야 할 것이다.
우선 MyApp.js 에 상태값을 관리하는 코드를 아래와 같이 작성한다.
import logo from './logo.svg';
import './App.css';
import MyButton from './MyButton';
import { useState } from 'react';
function App() {
const [count, setCount] = useState(0);
return (
<div className="App">
<header className="App-header">
<img src={logo} className="App-logo" alt="logo" />
<p>
Edit <code>src/App.js</code> and save to reload.
</p>
<a
className="App-link"
href="https://reactjs.org"
target="_blank"
rel="noopener noreferrer"
>
Learn React
</a>
<MyButton />
<MyButton />
<MyButton />
<MyButton />
</header>
</div>
);
}
export default App;
이제 MyButton 컴포넌트에서는 상태를 관리하지 않아도 되므로 관련 코드는 모두 삭제하기로 하자.
//import { useState } from 'react';
function MyButton() {
// const [count, setCount] = useState(0);
// function handleClick() {
// //alert('You clicked me!');
// setCount(count + 1);
// }
return (
<button onClick={handleClick}>I'm clicked {count} times!</button>
)
}
export default MyButton;
버튼을 클릭했을 때 무언가를 수행해야 하므로 아직 정의되지 않았지만, handleClick 이 수행되게 놔두었다. 그리고 버튼에는 공유되는 count 값이 표시되도록 그대로 놔두었다.
버튼에 표시되는 count 값은 MyButton 컴포넌트 상위인 App 에서 관리되는 값이며, 이 값은 App 에서 변경해주어야 하므로 App 컴포넌트에 이벤트핸들러 함수를 작성한다.
import logo from './logo.svg';
import './App.css';
import MyButton from './MyButton';
import { useState } from 'react';
function App() {
const [count, setCount] = useState(0);
function handleClick() {
setCount(count + 1);
}
return (
<div className="App">
<header className="App-header">
<img src={logo} className="App-logo" alt="logo" />
<p>
Edit <code>src/App.js</code> and save to reload.
</p>
<a
className="App-link"
href="https://reactjs.org"
target="_blank"
rel="noopener noreferrer"
>
Learn React
</a>
<MyButton />
<MyButton />
<MyButton />
<MyButton />
</header>
</div>
);
}
export default App;
마지막으로 남은 일은 MyButton 컴포넌트에게 count 값과 onClick 이벤트핸들러를 넘겨주는 작업이다.
App.js 에 기록한 MyButton 에 다음과 같이 기록한다.
<MyButton count={count} onClick={handleClick} />
<MyButton count={count} onClick={handleClick} />
<MyButton count={count} onClick={handleClick} />
<MyButton count={count} onClick={handleClick} />
MyButton 컴포넌트는 위 값을 받아서 사용하도록 수정되어야 한다.
//import { useState } from 'react';
function MyButton({ count, onClick }) {
// const [count, setCount] = useState(0);
// function handleClick() {
// //alert('You clicked me!');
// setCount(count + 1);
// }
return (
<button onClick={onClick}>I'm clicked {count} times!</button>
)
}
export default MyButton;
App.js 에서 count 와 onClick 이라는 이름으로 넘겼으므로, MyButton 컴포넌트에서도 받을 때 count 와 onClick 이라는 이름으로 받는다.
이제 프로그램을 실행시켜서 버튼을 누르면 버튼에 표시되는 모든 값이 동일하게 업데이트되는 것을 확인할 수가 있다.
'React' 카테고리의 다른 글
React diary - 로그인 페이지로 이동하자 - 라우터 (0) | 2024.12.09 |
---|---|
React 프로젝트 생성 오류 (Trouble Shooting) (1) | 2024.12.09 |
React - 컴포넌트 이벤트 핸들러 함수 추가하기 (0) | 2024.11.12 |
React 프로젝트 수정 (처음) (0) | 2024.11.11 |
React 프로젝트 분석 (2) | 2024.11.11 |