- 37
- 0
我现在正在学习 react,有些地方不知道怎么做才好。
项目进来时,会先请求后台判断是否有权限,用 redux 去存储状态值。
export const AuthRoute = ({ component: Component, redirect, loginStatus, ...data }) => (
<Route {...data} render={props => (
loginStatus ? (<Component {...props} />) : (
<Redirect to={redirect || {
pathname: '/home'
}} />
)
)} />
)
用 loginStatus 去判断是否有权限。
<Switch>
<AuthRoute path='/' exact component={IndexPage} loginStatus={loginStatus} />
<AuthRoute path='/home' exact component={HomePage} loginStatus={!loginStatus} redirect={{ pathname: '/' }} />
</Switch>
当去一个 news 的页面,需要有权限才能显示。所以在请求接口时(loginStatus 还没改改变时),就会重定向到 /home 页面。当请求完毕,更新了 redux ,变成有权限。
/home 页面有权限的就话就会重定向到 / 页面。
期望
权限变更后(有权限)应该跳回去刚进来时的页面(/news)。
现在
权限变更后,只会跳去定义好的重定向页面(/)。
那我是不是要拿到因没权限而重定向前的路径,当有权限后,就应该重定向回那个路径呢?
有没有什么好的解决方法。。。我在 github 找 demo 也找不到好的处理方法。
- 共 0 条
- 全部回答
-
゛若爱丶会伤つ@ 普通会员 1楼
React Router v4 是 React Router 的最新版本,它为React应用程序提供了一种更简单、更高效的路由管理方式。以下是一些基本的用法:
-
创建 Router:
javascript import { BrowserRouter as Router, Route, Switch } from 'react-router-dom'; -
定义路由: ```javascript const routes = [ { path: '/home', component: Home }, { path: '/about', component: About }, // 更多路由... ];
function App() { return (
); } ```// 更多路由... - 加载 Route: ```javascript import { BrowserRouter as Router, Route, Switch } from 'react-router-dom'; import Home from './Home';
function App() { return (
); }// 更多路由... export default App; ```
- 动态路由: ```javascript import { BrowserRouter as Router, Route, Switch } from 'react-router-dom'; import Home from './Home';
function App() { return (
); }// 更多路由... export default App; ```
- 重定向: ```javascript import { BrowserRouter as Router, Route, Switch } from 'react-router-dom'; import Home from './Home';
function App() { return (
); }// 更多路由... export default App; ```
以上就是React Router v4的基本用法,希望对你有所帮助。
-
- 扫一扫访问手机版
回答动态

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器更新之后。服务器里面有部分玩家要重新创建角色是怎么回事啊?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题函数计算不同地域的是不能用内网吧?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题ARMS可以创建多个应用嘛?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题在ARMS如何申请加入公测呀?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题前端小程序接入这个arms具体是如何接入监控的,这个init方法在哪里进行添加?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器刚到期,是不是就不能再导出存档了呢?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器的游戏版本不兼容 尝试更新怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器服务器升级以后 就链接不上了,怎么办?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器转移以后服务器进不去了,怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器修改参数后游戏进入不了,是什么情况?预计能赚取 0积分收益
- 回到顶部
- 回到顶部

