'dispatch is not a function'エラーの対処
概要
react-reduxの、actionをcomponentにdispatchするcontainerのところで
dispatch is not a function
のエラーに遭遇した。
下の図で言う星のところのあたり。
data:image/s3,"s3://crabby-images/3ef29/3ef298746107eb671aaae77a26c02dbef770f8a5" alt=""
※ 画像: UNIDIRECTIONAL USER INTERFACE ARCHITECTURES
詳細
const mapDispatchToProps = (dispatch) => {
return {
onChange: (selected) => {
dispatch(changeTab(selected));
}
}
}
export const VisibleMainAppBar = connect(
mapDispatchToProps
)(MainAppBar)
data:image/s3,"s3://crabby-images/7a13e/7a13edbf673d8def0fbd2ba8642e66c4297a2325" alt=""
原因と解決策
dispatchだけをconnectしているとこのエラーが起きる。ので、stateもconnectします。
stateを変更しないのであれば空でも大丈夫。
const mapDispatchToProps = (dispatch) => {
return {
onChange: (selected) => {
dispatch(changeTab(selected));
}
}
}
// 追加
const mapStateToProps = () => {
return {}
}
export const VisibleMainAppBar = connect(
mapStateToProps, // 追加
mapDispatchToProps
)(MainAppBar)
無事エラーが消えました。