首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用路由的ReactTS中的挂钩调用无效

使用路由的ReactTS中的挂钩调用无效
EN

Stack Overflow用户
提问于 2021-06-12 20:18:10
回答 1查看 53关注 0票数 0

我有一个PrivateRoute组件,

代码语言:javascript
运行
复制
interface Props {
    path: string,
    exact: boolean,
    component: React.FC<any>;
}

const PrivateRoute: React.FC<Props> = ({ component, path, exact }) => {
    return (
        <Route
            path={path}
            exact={exact}
        >
            {
                getCookie('name').length !== 0 ? component : <Redirect to="/login" />
            }
        </Route>
    );
}

但是当我试图在PrivateRoute中使用useState钩子时,我得到了invalid hook call错误。

例如,

代码语言:javascript
运行
复制
const [some, setSome] = useState(true);
// Calling this inside a private route will throw an error!

如何解决这个问题?

编辑

这就是PrivateRoute的用法,

代码语言:javascript
运行
复制
<Switch> // from react-router-dom
   <Route path="/login" component={Login} />
   <PrivateRoute path="/" exact component={Home} />
</Switch>

编辑2

codesandbox

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-06-13 23:56:30

这现在起作用了。

代码语言:javascript
运行
复制
export const PrivateRoute: React.FC<{
  component: React.FC<any>;
  path: string;
  exact: boolean;
}> = ({ component, path, exact }) => {
  const auth = useAuthProvider();

  return auth.isAuth ?  <Route path={path} exact={exact} component={component}/> : <Redirect to="/" />
};
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67948781

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档