Реагировать не рендеринг компонента после успешного перенаправления - PullRequest
0 голосов
/ 04 сентября 2018

Я новичок, чтобы отреагировать и попытался написать код, где пользователь пытается перейти на другую страницу после успешного входа в систему. Но я вижу, что перенаправление происходит с Home компонентом, но страница не передает, по крайней мере, мой оператор журнала. Видя пустую белую страницу. Мои компоненты выглядят так, как показано ниже.

index.js

import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import App from './App';
import registerServiceWorker from './registerServiceWorker';


import {
  Router,
  Route,
} from "react-router-dom";
import Home from './Home';
import history from './History';

ReactDOM.render(
  <Router history={history}>
  <div>
    <Route path="/" exact component={App} />
    <Route path="home" exact component={Home} />
  </div>
  </Router>,
  document.getElementById('root'));

registerServiceWorker();

App.js

import React, { Component } from 'react';
import axios from 'axios';
import history from './History';


class App extends Component {

constructor(){
    super();
    this.state = {
      username: '',
      password: '',
      userdata: [],
      isLogin: false
    };

  this.handleUserChange = this.handleUserChange.bind(this);
  this.handleSubmit = this.handleSubmit.bind(this);
}

handleSubmit(event){
    event.preventDefault();
    axios.post('https://api.github.com/user',{}, {
      auth: {
        username: this.state.username,
        password: this.state.password
      }
    }).then((response) => {
      console.log(response.data);
      this.setState({
        userdata: response.data,
        isLogin:true
      });
    }).catch(function(error) {
      console.log('Error on Authentication' + error);
  });
}

handleUserChange(event){
    this.setState({
      username : event.target.value,
    });
}

handlePasswordChange = event => {
  this.setState({
    password: event.target.value
  });
}

render() {
    if(this.state.isLogin){
     history.push({pathname: 'home', state: this.state.data});
     history.go('home');
    //browserHistory.push('home');
    }
    return (
      <form onSubmit={this.handleSubmit}>
        <label>
          username :
          <input type="text" value={this.state.username} onChange={this.handleUserChange} required/>
        </label>
        <label>
          password :
          <input type="password" value={this.state.password} onChange={this.handlePasswordChange} required/>
        </label>
        <input type="submit" value="LogIn" />
      </form>

    );
  }
}

export default App;

Home.js

import React, { Component } from 'react';
import axios from 'axios';

class Home extends Component {

  constructor(props){
    super(props);
    this.state = {
        Search:'',
        results:[]
      }

  }

  getInfo = () => {

    axios.get('https://api.github.com/search/users',{
    params: {
      q: this.state.Search,
      in:'login',
      type:'Users'
    }
  }).then(({ response }) => {
        this.setState({
          results: response.data.items.login
        })
      })
  }

  handleSearchChange(event){
    this.setState({
      Search: this.state.Search
    }, setInterval(() => {
      if (this.state.Search && this.state.Search.length > 1) {
        if (this.state.Search.length % 2 === 0) {
          this.getInfo();
        }
    }
  },500));

  }

  render(){
    console.log("Home page : " + this.props.data);
  return (
    <div>
      Home page {this.props.data}

    <form>
      <label>
        Search :
        <input type="text" placeholder="Search for..." value={this.state.Search} onChange={this.handleSearchChange} />
      </label>
    </form>
     </div>
  );
}
}

export default Home;

Любая помощь по какой ошибке я здесь делаю?

Спасибо

Ответы [ 2 ]

0 голосов
/ 04 сентября 2018

history.push({pathname: '/home', state: this.state.data}); и <Route path="/home" exact component={Home} />.

Отсутствует /

0 голосов
/ 04 сентября 2018

Вам не хватает /, поэтому маршрут должен быть таким, как показано ниже.

    <Route path="/home" exact component={Home} />

и при нажатии

history.push({pathname: '/home', state: this.state.data});
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...