首页 > 其他 > 详细

解决 react-router / react-router-dom v4 history不能访问的问题

时间:2017-11-14 13:30:48      阅读:466      评论:0      收藏:0      [点我收藏+]
首先使用router
import React, { Component } from ‘react‘;
import { BrowserRouter, Route } from ‘react-router-dom‘;
import { Provider } from ‘mobx-react‘;
import stores from ‘../store/index‘;
import Bundle from ‘../components/bundle‘;
import Hello from ‘bundle-loader?lazy!../components/hello.jsx‘;
 
// 这是按需加载,对于现在讨论的问题没有影响
const HelloAPP = () => (
    <Bundle load={Hello}>
        {(Hello) => <Hello />}
    </Bundle>
);
export default class App extends Component {
  constructor(props) {
    super(props);
  }
  render() {
    return (
      <Provider { ...stores }>
        <BrowserRouter basename="/">
          <Route path="/" component={HelloAPP}/>
        </BrowserRouter>
      </Provider>
    );
  };
}

  接着是子组件的使用history

import React, { Component } from ‘react‘;
// 需要这步,你要npm 这个,
import PropTypes from ‘prop-types‘;
export default class Hello extends Component {
  constructor(props) {
    super(props);
  }
  // 这一步是重点
  static contextTypes = {
    router: PropTypes.object.isRequired
  };
  test = () => {
    console.log(this.context);
    setTimeout(() => {
      this.context.router.history.push("/otherPath");
    }, 1000);
  };
  render() {
    return (
      <div>
        <button onClick={this.test}>按钮</button>
      </div>
    );
  };
}

  让我们看看this.context :

技术分享

解决 react-router / react-router-dom v4 history不能访问的问题

原文:http://www.cnblogs.com/rusr/p/7831813.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!