问题
I am using Redux and React for my project. I have some Routes in App.js. I also use the connect function in react-redux in my project. To prevent update blocking issue, I usually wrapped my component in this way
withRouter(connect(mapStateToProps, mapDispatchToProps)(App)),
However, If I changed order of withRouter and connect it doesn't work:
connect(mapStateToProps, mapDispatchToProps)(withRouter(App))
I have console.log the props in App.js. It already receives location and history props. I am figuring out the theory behind why the order does matter ?
回答1:
Could you refer to this https://reacttraining.com/react-router/core/api/withRouter, it clearly says that it doesn't work the other way around
回答2:
You can use it with the method compose
from redux library.
export default compose(
withRouter,
connect(mapStateToProps, mapDispatchToProps)
)(App);
回答3:
If someone still has the issue then plz follow this one
const ShowTheLocationWithRouter = withRouter(Login);
export default connect(mapStateToProps, mapDispatchToProps)(ShowTheLocationWithRouter);
来源:https://stackoverflow.com/questions/54247082/connect-and-withrouter-issue