[英]How to emulate window.location with react-router and ES6 classes
[英]How to emulate window.location with React Router 5?
我有一个由 Laravel 提供服务的 react SPA。我希望 SPA 能够访问一些也由 Laravel 提供服务的页面。
更新:
举个例子……在我基于 coreui-react 的应用程序中……我想允许用户打开使用 vuepress 构建的用户手册。 我希望能够在一个全新的页面中打开它,而不是将它捆绑到 SPA 中。 SPA 显示在https://test.local/用户手册位于https://test.local/docs
Link to="/docs" 让我回到 SPA,Link to="//test.local/docs" 也一样
我也试过在链接中放置 onClick={() => window.location = window.location.protocol + "//" + window.location.hostname + "/docs"} 但没有变化,除了它确实下降离开本地开发服务器(端口 3000)...但如果它在构建中 - 那么它仍然会被 ReactRouter 捕获
有一个建议是 StaticRouter 会这样做 - 但我看到的所有示例都是指 SPA 将使用的内容的服务器端呈现,而不是将您弹到服务器交付的页面。
我有点不知所措..我目前唯一的想法是将 SPA 从“/”移动到“/app”,并且在 SPA 内根本不处理“/”,希望 ReactRouter 可以允许通过
这似乎是 ReactRouter 中的一个长期问题.. 但在过去,您可以使用 <a href 或 window.location 强行退出 - 但似乎不再如此..
如果我理解正确,您可以使用“历史”:
const history = useHistory();
你必须从react-router-dom
导入useHistory
:
import { useHistory } from 'react-router-dom'
然后你可以使用:
history.push('/analytics')
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.