Как вы должны делать перенаправления страниц при завершении действия в потоке на основе реакции, используя реагирующий маршрутизатор и hashHistory

Основная проблема заключается в том, что делать history.push() как часть отправки не допускается, потому что вы не можете сделать отправку в пределах отправки. В качестве альтернативы действительному выполнению перенаправления в самой функции действия, в настоящее время я передаю функции обратного вызова методам действия, чтобы выполнять вызовы методов истории. Я не думаю, что это хороший способ сделать что-то, и я ищу лучший способ сделать это. Я делаю это во многих местах, в том числе в случае получения ошибок 401 - я очищаю информацию о сеансе и перехожу на страницу входа. Вот как выглядит мой код.

client.js

import React from "react";
import ReactDOM from "react-dom";
import { Router, Route, IndexRoute, hashHistory } from "react-router";

import CreateEntity from "./pages/CreateEntity";
import Dashboard from "./pages/Dashboard";
import Entity from "./pages/Entity";


const app = document.getElementById('app');


ReactDOM.render(
  <Router history={hashHistory}>
    <Route path="/" component={Layout}>
      <Route path="dashboard" component={Dashboard}></Route>
      <Route path="createEntity" component={CreateEntity}></Route>
      <Route path="entity/:name" component={Entity}></Route>
    </Route>
  </Router>,
app);

страниц /Entity.js

import React from "react";
import * as EntityActions from "../actions/EntityActions";
import EntityStore from "../stores/EntityStore";


export default class Entity extends React.Component {

  constructor() {
    super();
    this.finishDelete = this.finishDelete.bind(this);
    this.state = {
      description: undefined,
      name: undefined,
      id: undefined,
    };
  }

  delete() {
    EntityActions.deleteProject('mbrady', this.state.id, this.finishDelete)
  }

  finishDelete() {
    this.props.history.push("dashboard")
  }

  componentWillMount() {
    EntityStore.on("change", this.getProject);
    this.refresh()
  }

  componentWillUnmount() {
    EntityStore.removeListener("change", this.getProject);
  }

  render() {
    return (
      <div>
        <button class="btn btn-default" onClick={this.delete.bind(this)}>
          <span class="glyphicon glyphicon-trash"></span>
        </button>
      </div>
    );
  }
}

действия /EntityActions.js

import dispatcher from "../dispatcher";
import axios from "axios";
import * as config from '../AppConfig'

export function deleteEntity(user, id, delete_callback) {
  dispatcher.dispatch({type: "DELETE_ENTITY"});
  const url = "http://localhost:"+port+"/"+config.appName+"/some_url";
  axios.delete(url)
    .then((response) => {
      dispatcher.dispatch({type:"DELETE_ENTITY_FULFILLED", payload: response.data});
      console.log(delete_callback)
      delete_callback(response.data);
    })
    .catch((err) => {
      dispatcher.dispatch({type:"DELETE_ENTITY_FAILED", payload: err})
    })
}

магазины /EntityStore.js

import { EventEmitter } from "events";

import dispatcher from "../dispatcher";


class CurrentProjectStore extends EventEmitter {

  constructor() {
    super()
    this.project = undefined;
  }

  handleActions(action) {
    switch(action.type) {
      case "DELETE_PROJECT": {
        break;
      }
      case "DELETE_PROJECT_FAILED": {
        break;
      }
      case "DELETE_PROJECT_FULFILLED": {
        this.project = undefined
        break;
      }
    }
  }

}

const projectStore = new CurrentProjectStore;
dispatcher.register(projectStore.handleActions.bind(projectStore));

export default projectStore;

0 ответов

Другие вопросы по тегам