React

Redux_여러 개의 컴포넌트

chaarles 2020. 6. 9. 15:13

여러 개의 컴포넌트를 각각 구동하게 하기 위해선

modules 폴더 안의 index.js를 만들어 combine 시킨 뒤 쓰면 된다.

(또는 기존 src의 index.js 폴더 안에 넣어도 쓸 수 있다.)

 

App.js

import React, { Component } from "react";
import Com1 from "./components/Com1";
import Com2 from "./components/Com2";

class App extends Component {
  render() {
    console.log("App Call");
    return (
      <div>
        <Com1 />
        <Com2 />
      </div>
    );
  }
}
export default App;

 

 

components/Com1.js

import React from "react";
import { connect } from "react-redux";
import { increase, decrease } from "../modules/com1";

// 1. Component
//Com1에서 사용할 변수 지정
const Com1 = ({ number, OnIncrease, OnDecrease }) => {
  console.log("Component Call");
  return (
    <div>
      <h1>{number}</h1>
      <div>
        <button onClick={OnIncrease}>+1</button>
        <button onClick={OnDecrease}>-1</button>
      </div>
    </div>
  );
};

// 4. Store 생성(index.js)

// 5. state를 변수로 받은 뒤 Props로 전달(State to Props)
const stateToProps = (state) => {
  console.log("StateToProps Call");
  console.log(state.com1.number);
  return {
    //rootReducer에서 복수의 state를 combine 했으므로, 각자 따로 지정해야 한다.
    number: state.com1.number,
  };
};

// 6. Dispatch to Props
// 파일 분리 시 export 필요
// function increase() call 하면 reducer(여기선 counter)의 INCREASE를 전달하라고 요청
const dispatchToProps = (dispatch) => ({
  // OnIncrease 부르면 INCREASE 실행
  OnIncrease: () => {
    console.log("increase");
    dispatch(increase());
  },
  OnDecrease: () => {
    console.log("decrease");
    dispatch(decrease());
  },
});

// 7. Connect
// 8. Connect한 Container를 수정
export default connect(stateToProps, dispatchToProps)(Com1);

 

components/Com2.js

import React from "react";
import { connect } from "react-redux";
import { increase, decrease } from "../modules/com2";

// 1. Component
//Com2에서 사용할 변수 지정
const Com2 = ({ number, OnIncrease, OnDecrease }) => {
  console.log("Component Call");
  return (
    <div>
      <h1>{number}</h1>
      <div>
        <button onClick={OnIncrease}>+1</button>
        <button onClick={OnDecrease}>-1</button>
      </div>
    </div>
  );
};

// 4. Store 생성(index.js)

// 5. state를 변수로 받은 뒤 Props로 전달(State to Props)
const stateToProps = (state) => {
  console.log("StateToProps Call");
  console.log(state.com2.number);
  return {
    //rootReducer에서 복수의 state를 combine 했으므로, 각자 따로 지정해야 한다.
    number: state.com2.number,
  };
};

// 6. Dispatch to Props
// 파일 분리 시 export 필요
// function increase() call 하면 reducer(여기선 counter)
// 의 INCREASE를 전달하라고 요청하는 것.
const dispatchToProps = (dispatch) => ({
  // OnIncrease 부르면 INCREASE 실행
  OnIncrease: () => {
    console.log("increase");
    dispatch(increase());
  },
  OnDecrease: () => {
    console.log("decrease");
    dispatch(decrease());
  },
});

// 7. Connect
// 8. Connect한 Container를 수정
export default connect(stateToProps, dispatchToProps)(Com2);

 

modules/index.js

import { combineReducers } from "redux";
import com1 from "./com1";
import com2 from "./com2";

const rootReducer = combineReducers({
  com1,
  com2,
});

export default rootReducer;

 

 

modules/com1.js

// 2. initializing state(초기화 state)
const initialState = {
  number: 0,
};

// 3. Reducer (데이터의 갱신이 일어나는 곳, 가장 중요!, 컴포넌트 이름과 같은 소문자로 쓴다.)

// const 선언
const INCREASE = "com1/INCREASE";
const DECREASE = "com1/DECREASE";

export const increase = () => ({ type: INCREASE });
export const decrease = () => ({ type: DECREASE });
function com1(state = initialState, action) {
  //state에 초기값을 넣기 위해 가장 먼저 실행한다. Default Reducer을 실행한다.
  console.log("Reducer Call");
  switch (action.type) {
    case INCREASE:
      console.log("com1_switch_INCREASE");
      return {
        number: state.number + 1,
      };
    case DECREASE:
      return {
        number: state.number - 1,
      };

    default:
      console.log("Default Reducer");

      return state;
  }
}

export default com1;

 

modules/com2.js

// 2. initializing state(초기화 state)
const initialState = {
  number: 0,
};

// 3. Reducer (데이터의 갱신이 일어나는 곳, 가장 중요!, 컴포넌트 이름과 같은 소문자로 쓴다.)

// const 선언
const INCREASE = "com2/INCREASE";
const DECREASE = "com2/DECREASE";

export const increase = () => ({ type: INCREASE });
export const decrease = () => ({ type: DECREASE });
function com2(state = initialState, action) {
  //state에 초기값을 넣기 위해 가장 먼저 실행한다. Default Reducer을 실행한다.
  console.log("Reducer Call");
  switch (action.type) {
    case INCREASE:
      return {
        number: state.number + 1,
      };
    case DECREASE:
      return {
        number: state.number - 1,
      };

    default:
      console.log("Default Reducer");

      return state;
  }
}

export default com2;

 

src/index.js

import React from "react";
import ReactDOM from "react-dom";
import "./index.css";
import App from "./App";
import * as serviceWorker from "./serviceWorker";
import { createStore } from "redux";
import { Provider } from "react-redux";
import rootReducer from "./modules";

const store = createStore(rootReducer);

ReactDOM.render(
  <Provider store={store}>
    <App />
  </Provider>,
  document.getElementById("root")
);

serviceWorker.unregister();