Как вы должны делать перенаправления страниц при завершении действия в потоке на основе реакции, используя реагирующий маршрутизатор и 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;