3은로그

React 기초 - Props 본문

React

React 기초 - Props

3은 2023. 1. 31. 23:14
728x90

Props란?

  •  컴포넌트에 데이터를 전달하는 방법

 

Counter 예제

App.js

import './App.css';
import MyHeader from './MyHeader';
import Counter from './Counter';

function App() {

  return (
    <div className="App">
      <MyHeader/>
        <Counter a = {1} b = {2} c = {3} d = {4} initialValue={5}/> 
    </div>
  );
}

export default App;

App.js에서 Counter 컴포넌트에게 여러 매개변수를 보낸다.

 

Counter.js

import React,{useState} from "react";

const Counter = (props) => {

    console.log(props);

    //0에서 출발
    //1씩 증가
    //1씩 감소
    //count 상태
    const [count, setCount] = useState(0);
    //count는 상태의 값
    //setCount는 count라는 상태를 변화시키는 상태변환 함수
    //useState(0)은 count의 값을 0으로 초기화

    const onIncrease = () => {
        setCount(count+1);
    }

    const onDecrease = () => {
        setCount(count-1);
    }

    return(
        <div>
            <h2>{count}</h2> 
            <button onClick={onIncrease}>+</button>
            <button onClick={onDecrease}>-</button>
        </div>
    )
}

export default Counter;

Counter.js에서 props로 매개변수를 받아서 콘솔에 찍어보면 아래 사진처럼 객체 안에 담겨서 잘 오는 것을 확인할 수 있다. 

 

props.initialValue 같은 방식으로 객체 안에 변수를 꺼내 쓸 수 있다. 이를 점표기법이라고 한다. 

 

 

여러 개의 prop을 전달할 때는 아래와 같은 방법으로 객체로 만들어서 전달할 수 있다. 

App.js

import './App.css';
import MyHeader from './MyHeader';
import Counter from './Counter';

function App() {

  const counterProps = {
    a: 1,
    b: 2,
    c: 3,
    d: 4,
    initialValue: 5,
  };

  return (
    <div className="App">
      <MyHeader/>
        <Counter {...counterProps}/> 
    </div>
  );
}

export default App;

 

● defaultProps

 

까먹을 거 같거나 중요한 prop일 때 사용한다. 

Counter.js

이런식으로 Counter.js 안에 defaultProps를 사용해서 전달받지 못한 props의 기본값을 설정해서 에러를 막을 수 있다.

이런 경우 App.js에서 initialValue를 props으로 보내주지 않아도 이미 설정되어 있기 때문에 오류가 발생하지 않는다.

 

 

Props로 동적인 데이터 전달

  • Props로 정적인 데이터뿐만 아니라 State 같은 동적인 데이터도 전달 가능하다. 

 

Counter 짝홀 나타내기 예제

Counter.js

return 부분에 OddEventResult 컴포넌트를 부르고 props으로 state인 count를 넘겨준다. 

 

OddEvenResult.js

Counter.js에서 넘겨받은 동적 데이터를 받아서 쓸 수 있다.

 

 

홀수 짝수가 잘 나온다

 

<추가>

컴포넌트를 다른 컴포넌트의 props으로 전달하는 것도 가능하다.

 

랜더링

  • 본인이 관리하고 본인의 가진 state가 변경될 때 리랜더
  • 나에게 내려오는 props가 변경될 때
  • 부모 요소의 state가 변경될 때 리랜더