我将我的第一个 Gatsby 项目部署到 github 页面:
repo:https
://github.com/michal-kurz/stfuandclick
gh-pages:https ://michal-kurz.github.io/stfuandclick/app/ (从gh-pages
分支生成)
它有一个页面,src/pages/app.tsx
使用Reach Router进行动态路由。
// app.tsx
const App = () => (
<>
<GlobalStyles />
<Provider store={store}>
<ThemeProvider theme={theme}>
<Router>
<Homepage path={`${BASE_URL}/app/`} />
<Team path={`${BASE_URL}/app/team/:teamName/`} />
</Router>
</ThemeProvider>
</Provider>
</>
)
// gatsby-node.js
exports.onCreatePage = async ({ page, actions }) => {
const { createPage } = actions
if (page.path.match(/^\/app/)) {
page.matchPath = '/app/*'
createPage(page)
}
}
注意:BASE_URL
等于/stfuandclick
生产环境版本和''
其他环境
在开发模式下gatsby develop
一切正常(/team/:teamName
/app/
/app/
打开/team/:teamName链接直接导致 404(除非之前通过 访问它进行缓存/app/
,但随后 ctrl + f5 再次导致 404)。
部署应用程序后,似乎似乎gatsby.node.js
无法正常工作。我最初怀疑它根本不起作用,但显然情况并非如此,因为注释所有代码会进一步破坏应用程序(团队页面在通过链接访问时突然中断/app
)。
我尝试在生产版本中为路径添加前缀,如下gatsby-node.js
所示:BASE_URL
exports.onCreatePage = async ({ page, actions }) => {
const { createPage } = actions
if (page.path.match(/^\/stfuandclick\/app/)) {
page.matchPath = '/stfuandclick/app/*'
createPage(page)
}
}
并且还分别为两条路径中的每一条添加前缀gatsby-node.js
,但没有运气。
pathPrefix
我确实有gatsby-config.json
:(这里有完整的配置)
module.exports = {
pathPrefix: '/stfuandclick',
// ...
}
我使用以下纱线脚本进行部署:(此处为完整的 package.json)
"deploy": "gatsby build --prefix-paths && gh-pages -d public"
我可以做些什么来使我的路由工作?