nextjs-github-pages

nextjs-github-pages

部署Next.js应用到GitHub Pages的自动化流程

此项目提供了将Next.js应用部署到GitHub Pages的详细流程。内容包括Next.js配置、GitHub仓库设置和自动化部署实现。通过GitHub Actions实现持续集成和部署,无需SSH密钥或个人访问令牌。指南还涵盖静态导出和基本路径设置等关键问题,确保应用在GitHub Pages上的正常运行。

Next.jsGitHub Pages静态导出自动部署GitHub ActionsGithub开源项目

Next.js GitHub Pages

使用GitHub Actions将Next.js部署到GitHub Pages。查看已部署的应用 🚀

现在支持Next.js App Router了!如果你需要Pages Router支持,请点击这里

⚠️ 注意!GitHub Pages 支持无服务器或边缘函数。这意味着动态功能将被禁用。查看所有不支持的功能


配置Next.js

Next.js配置

首先,你需要配置Next.js以部署静态导出。这是GitHub Pages工作所必需的。

  1. 打开next.config.mjs文件
  2. 添加以下内容:
/** @type {import('next').NextConfig} */ const nextConfig = { /** * 为App Router启用静态导出。 * * @see https://nextjs.org/docs/app/building-your-application/deploying/static-exports */ output: "export", /** * 设置基本路径。这是你GitHub仓库的slug。 * * @see https://nextjs.org/docs/app/api-reference/next-config-js/basePath */ basePath: "/nextjs-github-pages", /** * 禁用基于服务器的图像优化。Next.js不支持 * 静态导出的动态功能。 * * @see https://nextjs.org/docs/app/api-reference/components/image#unoptimized */ images: { unoptimized: true, }, }; export default nextConfig;
  1. 保存next.config.mjs

  2. 最后,在/public目录中放置一个.nojekyll文件,以禁止GitHub Pages尝试创建Jekyll网站。

. ├── app/ ├── public/ │ └── .nojekyll ├── next.config.js

完美!这就是你需要配置Next.js以在GitHub Pages上部署的全部内容。

page.tsx中添加基本路径

接下来,你需要在page.tsx文件中的图像添加基本路径。这是图像在GitHub Pages上显示所必需的。

  1. 打开app/page.tsx
  2. 找到Image组件
  3. src属性中添加/nextjs-github-pages/(或你GitHub仓库的slug):
<Image src="/nextjs-github-pages/vercel.svg" alt="Vercel Logo" className={styles.vercelLogo} width={100} height={24} priority />
  1. 保存page.tsx文件

通过阅读官方文档了解更多关于basePath和图像的信息。


配置GitHub仓库

接下来,你需要配置GitHub以通过GitHub Actions进行自动部署。

启用GitHub Pages

以下设置使用Github Action Deploy Pages进行部署。我更喜欢这个工作流程,因为你不需要生成SSH密钥或使用个人访问令牌。

  1. 转到你仓库的Settings标签
  2. 点击侧边栏中的"Pages"
  3. 在"Build and Deployment"下,选择"GitHub Actions"作为源:

github pages设置的截图

设置GitHub Action

这就是魔法发生的地方!这个工作流文件会在你推送到main分支时自动构建和部署应用。

  1. 创建.github/workflows/deploy.yml文件
  2. 粘贴https://github.com/gregrickaby/nextjs-github-pages/blob/main/.github/workflows/deploy.yml的内容
  3. 保存deploy.yml文件

推送到GitHub

现在一切都配置好了,你可以提交你的代码并推送到GitHub。这将触发GitHub Action工作流程并将你的应用部署到GitHub Pages。

git add . && git commit -m "Initial commit" && git push

你应该在几分钟内看到你的网站部署到GitHub Pages。🚀


总结

感谢阅读,希望这对你有所帮助。如果你发现任何错误,请提交一个issue。祝你好运!🍻


编辑推荐精选

Vora

Vora

免费创建高清无水印Sora视频

Vora是一个免费创建高清无水印Sora视频的AI工具

Refly.AI

Refly.AI

最适合小白的AI自动化工作流平台

无需编码,轻松生成可复用、可变现的AI自动化工作流

酷表ChatExcel

酷表ChatExcel

大模型驱动的Excel数据处理工具

基于大模型交互的表格处理系统,允许用户通过对话方式完成数据整理和可视化分析。系统采用机器学习算法解析用户指令,自动执行排序、公式计算和数据透视等操作,支持多种文件格式导入导出。数据处理响应速度保持在0.8秒以内,支持超过100万行数据的即时分析。

AI工具酷表ChatExcelAI智能客服AI营销产品使用教程
TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
AIWritePaper论文写作

AIWritePaper论文写作

AI论文写作指导平台

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

AI辅助写作AI工具AI论文工具论文写作智能生成大纲数据安全AI助手热门
博思AIPPT

博思AIPPT

AI一键生成PPT,就用博思AIPPT!

博思AIPPT,新一代的AI生成PPT平台,支持智能生成PPT、AI美化PPT、文本&链接生成PPT、导入Word/PDF/Markdown文档生成PPT等,内置海量精美PPT模板,涵盖商务、教育、科技等不同风格,同时针对每个页面提供多种版式,一键自适应切换,完美适配各种办公场景。

AI办公办公工具AI工具博思AIPPTAI生成PPT智能排版海量精品模板AI创作热门
潮际好麦

潮际好麦

AI赋能电商视觉革命,一站式智能商拍平台

潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。

iTerms

iTerms

企业专属的AI法律顾问

iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。

SimilarWeb流量提升

SimilarWeb流量提升

稳定高效的流量提升解决方案,助力品牌曝光

稳定高效的流量提升解决方案,助力品牌曝光

Sora2视频免费生成

Sora2视频免费生成

最新版Sora2模型免费使用,一键生成无水印视频

最新版Sora2模型免费使用,一键生成无水印视频

下拉加载更多