目的:提交代码,自动触发构建,并发布到 Github Pages 上
不详细讲为什么,只讲在怎么做
项目准备
- 先在
github
上准备一个前端项目,我使用vue3
搭建了一个前端项目,技术栈为:vue3、vite、element-plus、pinia、vue-router、headlessui、tailwindcss、typescript
如何搭建可看这篇:《vue3 + vite + element-plus + tailwindcss + typescript 实战项目》
- 前端项目情况:只有
main
分支;项目文件如下图,代码在这
data:image/s3,"s3://crabby-images/d7001/d70015567e3a42dea8efa299a240a1321cd61af7" alt=""
Github Pages 配置
可以理解为免费的线上服务器,可展示 build 后的前端项目
- 开启配置
- 开启配置后,再刷新下页面(没有的话可强刷、关闭重进),可以看到访问地址
data:image/s3,"s3://crabby-images/81117/811179f4c78f2072a947a28a402d41c4d1f6c692" alt=""
- 访问下地址,发现页面是空白的,打开控制台,发现有 html 结构,原因是:会默认加载了该 github 项目下根目录的 index.html 文件
data:image/s3,"s3://crabby-images/46e2d/46e2d0e107acce7dffbbec1daf1ba796eb42eb9b" alt=""
- 现在去改一下该 github 项目根目录的 index.html 文件,加个点文字,然后提交代码
data:image/s3,"s3://crabby-images/4f7ad/4f7add027eaf000490c87199f73a9ad7cd3f976e" alt=""
等个 1、2 分钟,再刷新访问网址,就能看到最新的内容
- 至此简单的 github pages 配置完成,可以放只有一个 .html 的在线简历
Github Actions 配置
可以理解为 CI、CD
入门文档可看这篇:GitHub Actions 入门教程 - 阮一峰的网络日志
可以配合上面的 Github Pages,实现提交代码,自动构建并发布的效果。
- 更改
Github Pages
配置,改为Github Actions
形式
data:image/s3,"s3://crabby-images/b867d/b867d710ce1b403193003187f67323f874a690c7" alt=""
- 创建
Github Actions
的配置
data:image/s3,"s3://crabby-images/82ba8/82ba8b4fb91049c59d9066891da5a86baa9ae72c" alt=""
- 会帮我们生成了一个最基本的配置,然后我们提交到
mian
分支上
- 提交后,我们进入
Actions
下,可看到第一个workflows
data:image/s3,"s3://crabby-images/1f9e9/1f9e9dddddd485c400a1eb96126124586d376adf" alt=""
- 现在去改一下该 github 项目根目录的 index.html 文件,再加点文字,然后提交代码
data:image/s3,"s3://crabby-images/b1c95/b1c9561a8e1261ffe48c92ec69bd0a6b3ba55a19" alt=""
- 然后去
Actions
下,看又有了一个workflow
data:image/s3,"s3://crabby-images/da793/da79329e1dced169dd400c6b9ba45eb7da76f6ae" alt=""
- 然后等它成功后,访问下该项目的 Github Pages,看到内容也变化了
data:image/s3,"s3://crabby-images/ce76b/ce76b0fa5861d6009a74c0ab2aeea309020b500d" alt=""
- 至此简单的 github actions 配置完成,结合 github pages 可以放只有一个 .html 的在线简历,实现提交代码自动部署功能(虽然没啥用)
Vue3 + Vite 项目接入
上面的流程比较简单,真正的项目是需要:提交代码后,触发构建、生成 dist、部署 dist,最终实现页面内容的更新
本次项目的线上代码地址:在这
- 将项目拉取到本地:
git clone xxx
- 先在本地跑下构建命令,确定没得问题
- 更改
vite.config.ts
配置,将打包目录改为 github 项目目录
data:image/s3,"s3://crabby-images/14314/14314ecf8e9a7d457459231318ee3e087d65cb14" alt=""
- 更改
.github/workflows/static.yml
配置,加入打包流程:
data:image/s3,"s3://crabby-images/b332d/b332df4a2bc85f99bc7b4dfe621ecb187c1e4a82" alt=""
- 完整代码如下(pnpm 版):
yml
# Simple workflow for deploying static content to GitHub Pages
name: Deploy static content to Pages
on:
# Runs on pushes targeting the default branch
push:
branches: ['main']
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
# Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages
permissions:
contents: read
pages: write
id-token: write
# Allow only one concurrent deployment, skipping runs queued between the run in-progress and latest queued.
# However, do NOT cancel in-progress runs as we want to allow these production deployments to complete.
concurrency:
group: 'pages'
cancel-in-progress: false
jobs:
# Single deploy job since we're just deploying
deploy:
environment:
name: github-pages
url: ${{ steps.deployment.outputs.page_url }}
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- uses: pnpm/action-setup@v2
with:
version: 8
- name: Setup Node
uses: actions/setup-node@v3
with:
node-version: 20
cache: 'pnpm'
- name: Install dependencies
run: pnpm install
- name: Build
run: pnpm run build
- name: Setup Pages
uses: actions/configure-pages@v4
- name: Upload artifact
uses: actions/upload-pages-artifact@v3
with:
# Upload entire repository
path: './dist'
- name: Deploy to GitHub Pages
id: deployment
uses: actions/deploy-pages@v4
- 完整代码如下(npm 版):
yml
# Simple workflow for deploying static content to GitHub Pages
name: Deploy static content to Pages
on:
# Runs on pushes targeting the default branch
push:
branches: ['main']
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
# Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages
permissions:
contents: read
pages: write
id-token: write
# Allow only one concurrent deployment, skipping runs queued between the run in-progress and latest queued.
# However, do NOT cancel in-progress runs as we want to allow these production deployments to complete.
concurrency:
group: 'pages'
cancel-in-progress: false
jobs:
# Single deploy job since we're just deploying
deploy:
environment:
name: github-pages
url: ${{ steps.deployment.outputs.page_url }}
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Setup Node
uses: actions/setup-node@v3
with:
node-version: 20
cache: 'npm'
- name: Install dependencies
run: npm install
- name: Build
run: npm run build
- name: Setup Pages
uses: actions/configure-pages@v4
- name: Upload artifact
uses: actions/upload-pages-artifact@v3
with:
# Upload entire repository
path: './dist'
- name: Deploy to GitHub Pages
id: deployment
uses: actions/deploy-pages@v4
- 提交一下代码,然后去看
Actions
状态
data:image/s3,"s3://crabby-images/4647d/4647d44f19eba61bdb0068e3351e88f52eb7bcfc" alt=""
- 如果觉得频繁跳到 github 麻烦,可以安装 VScode 插件:GitHub Actions,然后在 VScode 里面直接看,并且还可点击直接打开网页的
github actions
内
data:image/s3,"s3://crabby-images/6d8a1/6d8a1316ab1be7e8bad22d62e8edaac14a089610" alt=""
- actions 成功后,打开项目的 github pages 访问地址,看看是否对了,已经对了
data:image/s3,"s3://crabby-images/675a0/675a020d9358df623f9a0a3af421c2131304a619" alt=""
- 然后点点页面,跳转下路由,都是对的
- 但是刷新下发现就 404 了,这不是浪费感情吗?
别急,这个原因是前端项目采用了history
的路由模式,对github pages
来说,访问https://mrhzq.github.io/vue3-vite-element-plus-tailwindcss-typescript/about
是访问/about
目录下的index.html
但我们哪有/about
目录,所以就去找访问目录(我们配的/dist
)下的404.html
,没找到就显示官方的 404 页面
问题处理
Github Pages 刷新后,页面 404
原因上面一行就有写,不赘述;正确的处理方式是:配置 nginx,将其他路径的访问全部都指向 index.html。但 Github Pages 我们没法这样去处理,所以只能"取巧"
1、前端项目采用hash
模式,重新触发actions
后,就完全正常了,但地址就不好看,看个人选择 。只需改路由就行,然后提交代码,等actions
成功,就可以任意刷新
data:image/s3,"s3://crabby-images/601f7/601f71ab845c6f965e56aaa0d9e6d3c723bfadbf" alt=""
2、在访问目录(我们配的/dist
)下的创建一个404.html
,内容跟index.html
一模一样,这样显示404.html
时也跟正常显示index.html
一样
我们可以在打包成功了,复制下
index.html
,命名为404.html
就行
a、package.json
新增一个404build
命令,用于生成404.html
json
{
// ...
"scripts": {
// ...
"404build": "cp dist/index.html dist/404.html"
},
}
b、.github/workflows/static.yml
新增一个404Build
步骤
data:image/s3,"s3://crabby-images/326ce/326ce8bf12cdab6a1234444c1e2737b79b799146" alt=""
yml
- name: 404Build
run: npm run 404build
c、提交代码,等actions
成功,就可以任意刷新
data:image/s3,"s3://crabby-images/d926b/d926baebe502138cf4b283e705379984aea3a24f" alt=""
Github Actions 失败处理
失败的,github 会发邮件给你哦
- 找到失败的
data:image/s3,"s3://crabby-images/063af/063afb0e81b64c71c5fb42c3c3cc02f6d55893ef" alt=""
- 进入详情
data:image/s3,"s3://crabby-images/4902e/4902ed954eb1caf5523c061075a9fa668bded623" alt=""
data:image/s3,"s3://crabby-images/efdf3/efdf32f6d4f4929c64d027176cc961b25154cc1b" alt=""
报错:Supported file patterns: package-lock.json,npm-shrinkwrap.json,yarn.lock
因为我使用的是 pnpm,所以项目中没有 package-lock.json 文件。
处理方式:npm i
,生成一个package-lock.json
然后提交代码