在 github 页面上部署后 Gatsby 链接失败

IT技术 reactjs deployment hyperlink gatsby github-pages
2021-05-27 04:06:23

我在 Gatsby(我的第一个)中创建了网站,但在部署页面上的Gatsby 链接出现问题。我正在使用gatsby-starter-react-bootstrap,它包括 gatsby 和 react-bootstrap,顾名思义:) 我在NavDropdown.Item 中找到了链接,它是 react-bootstrap 的一个元素。

import React from "react"
import {Link} from "gatsby"

import {Navbar, Nav, NavDropdown, Image} from "react-bootstrap"

import Logo from "../images/Logo_White_RGB_200x42px.png";
import customer_logo from "../images/customer_logo.svg";

const CustomNavbar = ({pageInfo}) => {

    return (
        <>
      <Navbar variant="dark" expand="md" id="site-navbar">
        {/* <Container> */}
        <Link to="/" className="link-no-style">
          <Navbar.Brand as="span">
              <Image src={Logo} />
          </Navbar.Brand>
        </Link>
        <Navbar.Toggle aria-controls="basic-navbar-nav" />
        <Navbar.Collapse id="basic-navbar-nav">
          <Nav className="mr-auto" activeKey={pageInfo && pageInfo.pageName}>
              <NavDropdown title="Project" id="collapsible-nav-dropdown">
                  <NavDropdown.Item><Link to="360-viewer" activeClassName="active">360 view</Link></NavDropdown.Item>
                  <NavDropdown.Item><Link to="map" activeClassName="active">map</Link></NavDropdown.Item>
                  <NavDropdown.Item><Link to="description" activeClassName="active">description</Link></NavDropdown.Item>
              </NavDropdown>
          </Nav>
          <Nav className="ml-auto">
              <Navbar.Text>
                  Customer: <a href="https://customer.com/"> Customer Group</a> <Image className="customer-logo" src={customer_logo}/>
              </Navbar.Text>
          </Nav>
        </Navbar.Collapse>
          {/* </Container> */}
      </Navbar>
    </>
    )
};

export default CustomNavbar

对于部署,我使用https://www.npmjs.com/package/gh-pages

在 localhost:8000 本地运行的开发版本完全正常。下拉菜单和所有链接都可以完美运行。当我尝试使用版本进行生产时,路由停止工作 - gatsby build 创建了 index.html 所在的公共文件夹。当我在 github 页面上部署页面时,路由也不起作用。

概括:

  1. 开发版工作正常
  2. 生产和部署版本有问题:
    • 当我点击下拉菜单时,下拉菜单没有打开,# 符号被添加到 URL 地址 - www.website.com/#
    • 当我添加到网站地址 360-viewer 时,页面正在打开,但是当我再次单击下拉菜单时,# 符号再次添加到 URL -www.website.com/360-viewer/#
1个回答

您的应用程序在 Github Pages 的生产中中断,因为与 localhost 不同,它不是从根 URL 提供的要解决此问题,您可以让 Gatsby 知道您的应用程序将从哪个路径提供服务。然后 Gatsby 将为您修复路由和链接。

gatsby-config.js

module.exports = {
  pathPrefix: "/your-repo-name",
}

然后将--prefix-paths标志添加到您的构建命令中:gatsby build --prefix-paths

他们在他们的文档中对此进行了更多解释:https : //www.gatsbyjs.org/docs/how-gatsby-works-with-github-pages/#deploying-to-a-path-on-github-pages