ReactJs this.props.router 未定义

IT技术 javascript reactjs react-router react-dom
2021-05-10 12:42:36

您好,我正在学习 React js,但遇到了一个问题。当我尝试使用 react router 更改回主页时,出现以下错误:

未捕获的类型错误:无法读取未定义的属性“推送”

这是我的代码,如您所见,我正在调用导航功能:

在此处输入图片说明

我的带有路由器的 client.js:

在此处输入图片说明

如果我更换this.props.router.push('/');this.props.history.push('/');它工作正常。可能是什么问题呢?

1个回答

您缺少一个调用super(). super()调用父类的构造函数,需要将父类的属性正确传递给该组件。您需要它来访问传递给组件的任何属性,包括router.

布局类的顶部应如下所示。

export default class Layout extends React.Component {
  constructor(props) {
    super(props)
  }

  navigate() {
    ...
  }

  render() {
    ...
  }
}

这里是关于类在 ES6 中如何工作的文档!

编辑 1:react-router

withRouter通过 进行导航时,您还需要使用新的this.props.router您可以通过将您的组件作为参数传递并导出它来完成此操作。withRouter函数只是将您的组件包装在另一个组件中,该组件将路由器props向下传递给您的组件。我应该指出,还有其他方法可以进行编程路由(单例、上下文等),但是在使用时,this.props.router.push您需要使用withRouter.

import { withRouter } from 'react-router' 
class Layout extends React.Component {
  constructor(props) {
    super(props)
  }

  navigate() {
    ...
  }

  render() {
    ...
  }
}

export default withRouter(Layout)

与路由器一起使用