React
Redux_여러가지 Container 작성법
chaarles
2020. 6. 9. 16:56
Redux Store와 연동되는 컴포넌트를 컨테이너 컴포넌트(Container Component)라 부른다.
여기 모든 container은 똑같이 작동한다.
1) 기본
component=Com1.js
module=com1.js
import React from "react";
import Com1 from "../components/Com1";
import { connect } from "react-redux";
import { increase, decrease } from "../modules/com1";
const Com1Container = ({ number, increase, decrease }) => {
return <Com1 number={number} onIncrease={increase} onDecrease={decrease} />;
};
const stateToProps = (state) => ({
number: state.com1.number,
});
const dispatchToProps = (dispatch) => ({
increase: () => {
console.log("increase");
dispatch(increase());
},
decrease: () => {
console.log("decrease");
dispatch(decrease());
},
});
export default connect(stateToProps, dispatchToProps)(Com1Container);
2) connect 함수 내부에 익명 함수 형태로 선언
import React from "react";
import Com1 from "../components/Com1";
import { connect } from "react-redux";
import { increase, decrease } from "../modules/com1";
const Com1Container = ({ number, increase, decrease }) => {
return <Com1 number={number} onIncrease={increase} onDecrease={decrease} />;
};
export default connect(
(state) => ({
number: state.com1.number,
}),
(dispatch) => ({
increase: () => dispatch(increase()),
decrease: () => dispatch(decrease()),
})
)(Com1Container);
3) Redux의 bindActionCreators 유틸 함수 이용
import React from "react";
import Com1 from "../components/Com1";
import { connect } from "react-redux";
import { increase, decrease } from "../modules/com1";
import { bindActionCreators } from "redux";
const Com1Container = ({ number, increase, decrease }) => {
return <Com1 number={number} onIncrease={increase} onDecrease={decrease} />;
};
export default connect(
(state) => ({
number: state.com1.number,
}),
(dispatch) =>
bindActionCreators(
{
increase,
decrease,
},
dispatch
)
)(Com1Container);
4) connect 함수가 내부적으로 bindActionCreators 작업 하도록, 액션 생성 함수로 이루어진 객체 형태로 넣어두기
import React from "react";
import Com1 from "../components/Com1";
import { connect } from "react-redux";
import { increase, decrease } from "../modules/com1";
const Com1Container = ({ number, increase, decrease }) => {
return <Com1 number={number} onIncrease={increase} onDecrease={decrease} />;
};
export default connect(
(state) => ({
number: state.com1.number,
}),
{
increase,
decrease,
}
)(Com1Container);
5) Hooks 이용
import React, { useCallback } from "react";
import Com1 from "../components/Com1";
import { useSelector, useDispatch } from "react-redux";
import { increase, decrease } from "../modules/com1";
const Com1Container = () => {
const number = useSelector((state) => state.com1.number);
const dispatch = useDispatch();
const onIncrease = useCallback(() => dispatch(increase()), [dispatch]);
const onDecrease = useCallback(() => dispatch(decrease()), [dispatch]);
return <Com1 number={number} onIncrease={onIncrease} onDecrease={onDecrease} />;
};
export default Com1Container;