0

0

如何正确配置 Vite 项目以在 GitHub Pages 上正常显示

聖光之護

聖光之護

发布时间:2026-03-10 12:13:05

|

908人浏览过

|

来源于php中文网

原创

如何正确配置 Vite 项目以在 GitHub Pages 上正常显示

Vite 项目部署到 GitHub Pages 后出现空白页,通常是因构建路径(base)未适配子路径导致资源 404;本文详解通过 vite.config.js 设置 build.base 为 './' 或动态路径,并配合 homepage 字段完成兼容部署。

vue/vite 项目部署到 github pages 后出现空白页,通常是因构建路径(base)未适配子路径导致资源 404;本文详解通过 vite.config.js 设置 build.base 为 './' 或动态路径,并配合 homepage 字段完成兼容部署。

GitHub Pages 默认将用户仓库托管在 https://.github.io/,而项目级站点(如 https://alperenkarslix.github.io/website/)属于子路径部署(subpath deployment)。此时,Vite 构建生成的 HTML 中引用的 JS/CSS 资源路径默认为绝对根路径(如 /assets/index.abc123.js),浏览器会尝试从 https://alperenkarslix.github.io/assets/... 加载——但实际资源位于 https://alperenkarslix.github.io/website/assets/...,导致 404,页面白屏。

根本解法是让 Vite 在构建时生成相对路径正确前缀的绝对路径。推荐在 vite.config.js 中显式配置 build.base:

// vite.config.js
import { defineConfig } from 'vite'

export default defineConfig({
  build: {
    base: './', // ✅ 关键:使用相对路径,所有资源引用变为 ./assets/...
    // 其他配置(如 rollupOptions、minify 等)
  }
})

该配置使生成的 index.html 中脚本引入形如:

<script type="module" src="./assets/index.abc123.js"></script>

浏览器会基于当前 HTML 文件位置(/website/)自动解析相对路径,精准定位资源。

⚠️ 注意事项:

Beautiful.ai
Beautiful.ai

AI在线创建幻灯片

下载
  • 若你使用 homepage 字段(如 "homepage": "https://alperenkarslix.github.io/website/"),Vite 不会自动读取它设置 base —— 这与 Create React App 不同。必须手动在 vite.config.js 中配置。
  • base: '/' 仅适用于用户主页(username.github.io),不适用于项目页(username.github.io/repo-name)。
  • 动态写法(兼容本地开发与生产):
    base: process.env.NODE_ENV === 'production' 
      ? '/website/' // 替换为你的仓库名
      : '/'

    但需确保仓库名拼写完全一致(区分大小写),且无额外路径层级。

同时,请确认你的 GitHub Pages 发布源已正确设置:

  • 进入仓库 Settings → Pages → Branch → 选择 gh-pages 分支 + / (root) 目录(若 gh-pages 分支中文件位于根目录);
  • 确保 npm run deploy 成功推送了 build/ 目录下的全部内容(含 index.html, assets/, favicon.ico 等)至 gh-pages 分支根路径。

最后验证:访问 https://alperenkarslix.github.io/website/(结尾带斜杠),打开浏览器开发者工具 → Network 标签页,刷新页面,检查所有 .js / .css 请求是否返回 200。若仍有 404,请检查 build/ 目录结构是否扁平(无嵌套 build/build/),并确认 vite.config.js 已被 Vite 正确加载(可临时添加 console.log('config loaded') 验证)。

总结:Vite + GitHub Pages 白屏问题本质是路径解析错位,核心只需一行配置 build.base: './',无需修改 package.json 的 homepage(它仅用于某些插件提示,不影响构建输出),即可实现开箱即用的子路径静态部署。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

454

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

546

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

334

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

530

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

576

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

6147

2023.08.17

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

4

2026.03.10

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 4.1万人学习

Git版本控制工具
Git版本控制工具

共8课时 | 1.6万人学习

Git中文开发手册
Git中文开发手册

共0课时 | 94人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号