Next打包部署到github page后,找不到静态资源导致样式失效的排查和解决方法

问题复现

可以看到并没有找到对应的文件。 输入826625219.github.io/SheetProjec... 后也是404

解决直接文件访问不到

GitHub Pages 默认会忽略以下划线开头的文件夹,不会读取里面的资源,在根目录中添加 .nojekyll空文件后,Pages 就能读取 _next文件夹中的资源了。

原理:

Github Pages 默认是基于 Jekyll 构建,Jekyll 是一个将纯文本转换为静态网站的工具,它构建的网站下各种目录都是特定的以下划线开头命名的文件夹,例如 _layouts、_posts ,它会忽略掉其它的以下划线开头的文件夹和文件。

.nojekyll 就是告诉 Github Pages 当前网站不是基于 Jekyll 构建的,不要忽略掉下划线开头的文件和文件夹。

可见 .nojekyll 主要就是用于 Github Pages 这种有默认规则的网站部署平台,如果是部署在自己的服务器上,可以把它删掉。

反之,如果你的网站不是 Jekyll 构建的,要部署到 Github Pages ,并且包含下划线开头的文件或文件夹,那么你就需要在根目录添加一个 .nojekyll 空文件。这样就能找到那个css文件了。

解决资源引用错误

在问题复现的控制台可以看到,错误的引用的资源路径为826625219.github.io/_next/stati...

我们进入部署分支(打包后的分支)查看

访问826625219.github.io/SheetProjec... 能成功是因为logi.html文件放在了根目录下,那么我们希望引用css资源也需要在错误的引用的资源路径的/_next之前加上/SheetProject。

如果要实现上述的目的,我们进行排查。在本地发现项目能正常运行,那么就不是我们在开发过程中路径错误导致的bug

而上线部署前有关键的一步是打包构建,在这一步里需要对next进行配置,对静态资源的访问加上前缀,参考 next.config.js: 为静态资源添加路径前缀并支持发布到 CDN | Next.js | Next.js中文网 (nextjs.cn)

js 复制代码
const nextConfig = {
....
  assetPrefix: "/SheetProject",
....
};

重新进行打包部署

等待2-5min后,打开我们部署的网页查看,成功解决问题

相关推荐
hexu_blog2 分钟前
前端vue 后端springboot如何实现图片去水印
前端·javascript·vue.js
whuhewei4 分钟前
React搜索框组件
前端·javascript·react.js
ZC跨境爬虫21 分钟前
跟着 MDN 学 HTML day_50:(深入理解 DOM 中的 Text 节点)
前端·javascript·microsoft·ui·html·媒体
ZC跨境爬虫21 分钟前
跟着 MDN 学 HTML day_51:(深入理解 XPathEvaluator 接口)
前端·javascript·ui·html·音视频
wjykp27 分钟前
5.cypher语句组合与复杂操作
linux·前端·javascript
吃好睡好便好2 小时前
在Matlab中用sphere( )函数绘制球面图
开发语言·前端·javascript·学习·算法·matlab·信息可视化
黑贝是条狗2 小时前
注册表破解chrome,edge阻止浏览器连接本地websocket
前端·javascript·数据库
ZC跨境爬虫2 小时前
跟着 MDN 学 HTML day_53:(深入理解 XPathResult 接口)
前端·javascript·ui·html·音视频
之歆2 小时前
DAY_24JavaScript 面向对象深度全解:Object、构造函数与 this 系统指南(上)
开发语言·前端·javascript·原型模式
Asurplus2 小时前
【VUE】17、使用JSEncrypt对数据加解密
javascript·vue.js·jsencrypt·rsa