我有一个简单的用例,在 React-Router 4 和 Redux 环境中似乎很难实现。
当用户登录时,会触发一个 redux 承诺操作,该操作会返回一个 API 令牌、到期日期和一些其他信息。何时以及如果实现了承诺,我将希望将用户重定向到另一个页面。
我无法弄清楚如何使用上述架构以编程方式重定向用户。想在Action.js里面做,但是感觉只能在Reducers.js里面做。即使我不确定如何开始。
到目前为止我发现的最好的方法是在我的视图中有一个 Redirect 组件,并让 Promise 将loggedIn 状态设置为true,如果loggedIn 道具在视图上为true,它将返回重定向道具,然后重定向用户到所需的页面。不知何故,对于一个简单的用例来说,这感觉像是很多额外的代码。
任何意见将是有益的。谢谢你。
动作.js:
import axios from 'axios';
export function login(email, password) {
return {
type: 'LOGIN_USER',
payload: axios.post('http://localhost:3114/api/users/authenticate',
{
email,
password,
}),
};
}
减速器.js
// Promise
// pending
// fulfilled
// rejected
const initalState = {
token: null,
expiryDate: '',
loading: false,
error: null,
};
// REDCUER
function loginReducer(state = initalState, action) {
switch (action.type) {
case 'LOGIN_USER_PENDING':
return { ...state, loading: true };
case 'LOGIN_USER_FULFILLED':
return {
...state,
loading: false,
token: action.payload.data.token,
expiryDate: action.payload.data.expires,
loggedIn: true,
};
case 'LOGIN_USER_REJECTED':
return { ...state, loading: false, error: `${action.payload}` };
default:
return state;
}
}
export default loginReducer;
登录视图.js
render() {
const { data, login, loggedIn } = this.props;
if (data.loggedIn) {
return <Redirect to="/users" push />;
}
return (
...
)
}
问候,埃米尔