解决 Vue 3 应用部署到 GitHub Pages 后,遇到 404 错误问题

在将 Vue 3 应用部署到 GitHub Pages 后,遇到 404 错误通常是由于 GitHub Pages 处理路由时的问题。Vue 3 使用 Vue Router 来管理前端路由,而 GitHub Pages 本身是静态托管服务,不支持处理 SPA(单页面应用)的客户端路由。因此,当你直接访问某个页面 URL(比如 https://yourusername.github.io/your-repo/some-page)时,GitHub Pages 会尝试查找一个实际的文件或目录,而不是通过 Vue Router 渲染该页面,导致 404 错误。
为了解决这个问题,你可以按照以下步骤操作:
1. 设置 base 路径
在 Vue 项目中,设置 base 路径是解决 GitHub Pages 路由问题的关键。你需要在 vue.config.js 中配置 publicPath,指向你项目的 GitHub Pages 路径。
在根目录下创建或修改 vue.config.js 文件,添加以下内容:

module.exports = {
  publicPath: process.env.NODE_ENV === 'production'
    ? '/your-repo-name/'  // 这里替换成你的仓库名称
    : '/',
}

注意
/your-repo-name/ 是你项目的 GitHub 仓库名。例如,如果你的 GitHub 仓库是 my-project,那么路径应该是 /my-project/
在开发环境中,publicPath 会保持为 /,以便本地开发时使用。
2. 配置 Vue Router 的 history 模式
如果你在 Vue 中使用 Vue Router,并且选择了 history 模式,你还需要做一些调整。history 模式会使用 HTML5 的 History API 来管理路由,但它依赖服务器的支持来处理刷新和跳转到页面时的 URL。GitHub Pages 不支持这种处理,所以你需要将 Vue Router 切换回 hash 模式,避免 URL 中出现 history 模式下的路径。
router/index.js 中配置 Vue Router:

const router = createRouter({
  history: createWebHashHistory(),  // 使用 hash 模式
  routes: [
    // 你的路由配置
  ],
})

这样,在 GitHub Pages 上部署后,所有的路由都会带上 #(例如:https://yourusername.github.io/your-repo/#/some-page),这能避免 404 错误。
3. 构建并部署
最后,构建项目并将构建结果部署到 GitHub Pages。可以通过以下命令生成生产构建:

npm run build

然后将 dist 文件夹中的内容推送到 GitHub 仓库的 gh-pages 分支或相应的分支,以使 GitHub Pages 服务于这些构建文件。

例如,你可以使用 gh-pages npm 包来自动化此过程:

npm install gh-pages --save-dev

然后在 package.json 中配置部署命令:

"scripts": {
  "deploy": "npm run build && gh-pages -d dist"
}

运行部署命令:

npm run deploy

这样,Vue 3 应用就可以正确部署到 GitHub Pages 上,并且不会再遇到 404 错误。
总结
vue.config.js 中设置 publicPath/your-repo-name/
在 Vue Router 中使用 hash 模式来避免 history 模式的路由问题。
通过 gh-pages 部署到 GitHub Pages。
这些步骤应该能解决你的问题,让 Vue 3 应用在 GitHub Pages 上顺利运行。

发布者:myrgd,转载请注明出处:https://www.object-c.cn/4957

Like (0)
Previous 2024年11月29日 下午3:37
Next 2024年11月29日 下午3:50

相关推荐

  • 在 WPF 中使用 Vlc.DotNet 和 LibVLCSharp.WPF 两种库来进行 VLC 的二次开发

    在 WPF 中使用 Vlc.DotNet 和 LibVLCSharp.WPF 两种库来进行 VLC 的二次开发,可以实现丰富的视频播放功能,比如播放本地视频、流媒体、控制播放、获取视频信息等功能。以下是对两者的介绍及开发步骤。 一、Vlc.DotNet 和 LibVLCSharp 的对比 特性 Vlc.DotNet LibVLCSharp.WPF 开发活跃度…

    2024年12月3日
    00
  • python反爬-图像验证码与滑块验证码的跳过反selenium检测,动态ip等问题

    针对反爬措施,Python可以使用以下策略来跳过图像验证码与滑块验证码、反检测Selenium,以及通过动态IP规避限制。这是一个分步说明: 1. 图像验证码的跳过与破解1.1 图像验证码处理对于简单的图像验证码,可以使用 OCR 技术直接识别验证码内容。常用库包括:Tesseract-OCR: 一款开源 OCR 工具。Pytesseract: Tesser…

    2024年11月28日
    00
  • 微信小程序RequestTask.onChunkReceived 监听分块数据接收事件接口

    在微信小程序中,RequestTask.onChunkReceived 是用于监听分块数据接收事件的接口。此功能适用于需要逐步接收大数据(例如流媒体、文件分块等)的场景,可以显著提升大文件传输的性能和用户体验。 以下是详细介绍和使用方法: 1. 功能说明用途:监听通过 wx.request 或 wx.downloadFile 发起的请求过程中,每次接收到的数…

    2024年11月28日
    00
  • 部署 Harbor 时,如果运行 install 脚本报错可能导致问题的

    在部署 Harbor 时,如果运行 install 脚本报错,可能是网络问题导致的。以下是排查网络问题的方法: 1. 检查网络连通性 测试目标网络的连通性: 检查 DNS 配置: 如果解析失败,检查 /etc/resolv.conf 中的 DNS 配置,或者尝试手动指定公共 DNS,如 Google 的 8.8.8.8 或阿里云的 223.5.5.5。 2.…

    2024年12月9日
    00
  • 在 Apache Kafka 中消息的消费和传递通过消费者与 Kafka 的分布式系统协作完成

    在 Apache Kafka 中,消息的消费和传递是通过消费者(Consumer)与 Kafka 的分布式系统协作完成的。以下是消息传递的主要流程: 1. Producer 生产消息到 Kafka 2. Consumer 消费消息 Kafka 中消费者的消息消费流程如下: 2.1 订阅主题 消费者通过 Kafka 客户端订阅一个或多个主题。它可以: 2.2 …

    2024年12月9日
    00
  • 浏览器跨域请求中携带 Cookie需要同时在前端和后端进行配置

    浏览器跨域请求中,要让请求携带 Cookie,需要同时在前端和后端进行配置。以下是实现的方法: 前端配置 在前端代码中使用 fetch 或 Axios 发起请求时,需要设置 credentials 属性: 1. Fetch 示例 2. Axios 示例 后端配置 在后端需要允许跨域请求,并确保 Cookie 能够正常传递。 1. 设置 Access-Cont…

    2024年12月9日
    00
  • PHM技术:一维信号时序全特征分析(统计域/频域/时域)信号处理

    PHM(Prognostics and Health Management,预测与健康管理)技术中的一维信号时序特征分析,旨在从信号中提取与设备健康状态相关的多种特征。以下是针对统计域、频域和时域特征分析的详细介绍和常见方法。 1. 时域特征分析时域特征直接从原始信号提取,描述信号的统计特性或时间行为。这些特征反映信号的幅值、变化趋势和波形形状。1.1 常用…

    2024年11月28日
    00
  • 在国内访问 GitHub 可能会遇到加载缓慢或无法打开的问题

    在国内访问 GitHub 可能会遇到加载缓慢或无法打开的问题,这通常与网络连接、DNS 设置或网络限制有关。以下是几种解决方法: 1. 更改 DNSDNS 配置错误可能导致 GitHub 无法正常访问。可以尝试修改 DNS 为公共 DNS 服务:推荐使用:阿里云 DNS:223.5.5.5 和 223.6.6.6Google DNS:8.8.8.8 和 8.…

    2024年11月27日
    00
  • 把一个矩形div变成一个直角三角形

    要将一个矩形 div 变成一个直角三角形,可以通过 CSS 的一些属性进行实现。具体的方法是利用 border 属性来隐藏矩形的部分,留下一个直角三角形的形状。以下是实现的步骤:CSS 方法: 解释:width 和 height 设置为 0:通过将 div 的宽度和高度设置为 0,实际上把矩形的主体部分隐藏了。border-left 和 border-bot…

    2024年11月27日
    00
  • java中使用 Arrays.asList()新增报错问题解决方法

    Arrays.asList() 返回的是一个固定大小的列表。如果你尝试使用该列表进行添加、删除等修改操作,会抛出 UnsupportedOperationException 异常。这是因为 Arrays.asList() 返回的列表背后是一个数组,它的大小是固定的,不能进行动态修改。解决方法使用 ArrayList 包装 Arrays.asList() 的结…

    2024年12月2日
    00
  • 在 Spring Boot 中实现定时任务,通过 Spring Task Scheduling 来完成

    在 Spring Boot 中实现定时任务,可以通过 Spring Task Scheduling 来轻松完成。Spring 提供了多种方法来调度任务,其中使用 @Scheduled 注解是最常见且简单的方式。 步骤:在 Spring Boot 中实现定时任务 1. 启用定时任务 首先,确保在 Spring Boot 应用的主类或配置类中启用定时任务功能: …

    2024年11月26日
    00
  • 多方面的优化包括启动时间、React Native 速度提升 550% 运行时性能以及渲染效率的提升

    React Native 速度提升 550% 可能涉及多方面的优化,包括启动时间、运行时性能以及渲染效率的提升。这通常是通过框架改进、代码优化和工程实践的结合来实现的。以下是实现 React Native 性能大幅提升的一些关键方法和策略: 1. 启动时间优化 1.1 减少 JS Bundle 大小 1.2 预加载资源 1.3 使用优化的原生模块 2. 渲染…

    2024年12月7日
    00
  • 在 Kubernetes 中,解决kubelet下载docker私有仓库验证问题

    在 Kubernetes 中,kubelet 默认需要访问容器镜像时,能够成功从 Docker 私有仓库拉取镜像。遇到验证问题时,通常需要解决 镜像仓库认证 和 TLS 证书配置 问题。以下是具体步骤: 1. 配置私有镜像仓库认证如果私有镜像仓库需要身份验证,需要配置 imagePullSecrets 或在每个节点设置全局 Docker 登录。方法 1:使用…

    2024年12月2日
    00
  • 在 Neo4j 中存储 Liquidity Structure(的层次和关联结构)

    在 Neo4j 中存储 Liquidity Structure(流动性结构)的层次和关联结构时,可以使用其图数据库的特性:节点(Node)表示实体,关系(Relationship)表示这些实体之间的连接。流动性结构通常涉及多层次的实体(如母公司、子公司、账户、资金池等)及其关联关系。 以下是具体实现步骤: 1. 设计数据模型节点类型:实体层次(Hierarc…

    2024年12月2日
    00
  • HTTP POST/GET 接口测试工具是开发和测试

    HTTP POST/GET 接口测试工具是开发和测试网络应用时必不可少的工具,用于验证 HTTP 请求的正确性、响应的状态和数据格式。以下是常用的 HTTP 接口测试工具及其功能介绍。 1. 常用的 HTTP 接口测试工具 1.1 Postman Postman 是目前最流行的 API 测试工具,适用于 RESTful 和 GraphQL 接口的测试。 功能…

    2024年11月25日
    00

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

在线咨询: QQ交谈

邮件:723923060@qq.com

关注微信