使用GitHub Actions打包前端项目并自动上传到Releases
创作时间:
作者:
@小白创作中心
使用GitHub Actions打包前端项目并自动上传到Releases
引用
1
来源
1.
https://www.mulingyuer.com/archives/1065/
前言
本文将详细介绍如何使用GitHub Actions自动打包前端项目并上传到Releases。GitHub Actions是一种持续集成和持续部署(CI/CD)工具,可以帮助开发者自动化执行各种任务,如代码构建、测试和部署。
教程
创建workflows
首先需要在项目根目录创建.github/workflows目录:
.github
└─ workflows
创建yml文件
在workflows目录下创建一个名为releases.yml的文件:
├─ .github
│ └─ workflows
│ └─ releases.yml
vscode 插件安装
建议安装GitHub官方插件:GitHub Actions。这个插件能在编写yml文件时提供代码高亮和语法提示。
配置工作流名称和触发条件
在releases.yml中配置工作流名称和触发条件:
name: 打包插件并发布到Releases
on:
push:
branches:
- main
workflow_dispatch: # 允许手动触发该工作流
增加工作jobs
一个yml文件可以配置多个job工作,每个job下面可以定义具体的操作步骤:
jobs:
job1:
job2:
增加build的job工作
我们需要一个代码的运行环境,这里采用GitHub官方提供的ubuntu-latest系统:
jobs:
build:
name: 打包工作
runs-on: ubuntu-latest
创建步骤
每个工作都可以有很多步骤,所以需要一个统一的入口来进行管理:
jobs:
build:
name: 打包工作
runs-on: ubuntu-latest
steps:
- 具体步骤1
- 具体步骤2
...
步骤:克隆仓库代码
开源仓库
对于开源仓库,可以直接克隆代码:
steps:
- name: 克隆代码
run: |
git clone https://github.com/<your-username>/<your-repository>.git
cd <your-repository>
git checkout main
私有仓库
对于私有仓库,需要使用token进行认证:
steps:
- name: git全局设置
run: |
git config --global user.name "github-actions[bot]"
git config --global user.email "github-actions[bot]@users.noreply.github.com"
- name: 克隆代码
env:
TOKEN: ${{ secrets.MY_TOKEN }}
run: |
git clone https://x-access-token:${TOKEN}@github.com/<your-username>/<your-repository>.git
cd <your-repository>
git checkout main
步骤:安装node
由于环境中没有node,需要手动安装:
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version: 20
cache: 'npm'
- run: npm ci
- run: npm test
步骤:安装pnpm
steps:
- name: 安装pnpm
run: npm install -g pnpm@latest
步骤:安装依赖
steps:
- name: 安装依赖
run: |
cd chrome-extension
pnpm install
步骤:打包项目
steps:
- name: 打包插件
run: |
cd chrome-extension
pnpm run build
步骤:创建zip文件
steps:
- name: 创建谷歌浏览器扩展zip文件
run: |
cd chrome-extension
zip -r ../chrome-extension.zip ./dist
- name: 创建serverless模版zip文件
run: |
zip -r ./serverless-template.zip ./serverless-template
步骤:获取版本号
从package.json文件中获取版本号:
steps:
- name: 获取新版本号
id: get_chrome_extension_version
run: |
VERSION=$(node -p "require('./chrome-extension/package.json').version" 2>/dev/null || echo "v0.0.1")
echo "VERSION=${VERSION}" >> $GITHUB_ENV
echo "New version:${VERSION}"
步骤:创建Release
使用GitHub Actions创建Release:
steps:
- name: 创建Release
id: create_release
uses: softprops/action-gh-release@v2
with:
tag_name: ${{ env.VERSION }}
name: v${{ env.VERSION }}
draft: false
prerelease: false
files: |
./chrome-extension.zip
./serverless-template.zip
触发
当向main分支推送代码时,或者合并分支时,都会触发该工作流。可以在仓库的Actions中查看进展。此外,还可以手动触发该工作流。
热门推荐
老登味?细聊《哪吒之魔童闹海》里的三个爹,反父权也要有新解说
外资品牌与国产品牌快速门全面对比:哪一个更适合你?
如何打包JS和CSS文件:从构建工具到CDN的全方位指南
雅思考试对学习的七大好处
资产配置如何实现最优效果?这种最优效果如何评估和调整?
担保借条怎么写才规范
嗅觉解密梦境:为什么香气能左右你的梦?
本命年吉祥物选购指南:金饰与玉石的选择建议
待摊费用怎么做账
厦门大学艺术学院举办王卫“光·尘”雕塑作品展
安卓手机如何设置,避免应用自动下载?
为何三元催化器成了汽车盗窃的新目标?
勒布朗詹姆斯与斯蒂芬·A·史密斯再起冲突
强制执行保留生活费申请书范例及法律程序说明
提升光伏效率:降低热损耗和电阻损耗的实用技术
劳动合同到期后,员工可以直接走人吗?
坚持吃水煮蛋两个月,女性或将迎来三大惊喜变化
我国第四代核电技术研发应用领先世界 解决核能安全利用世界级难题
《危机边缘》第五季:科幻与人性的深刻交织与震撼收官总结
婚姻支持系统:构建幸福婚姻的全方位服务体系
胃镜和肠镜检查是否需要麻醉?三种麻醉方式详解
胃镜和肠镜检查是否需要麻醉?三种麻醉方式详解
和田玉籽料皮色鉴别指南:五大误区与四大判断标准
天空为什么是蓝色的
揭秘Jane Street低延迟系统的优化技巧——减少系统抖动
雇主必读!瑞士养老金制度全方位解析
EVA材质是什么?EVA材质的用途有哪些?
体检查出肺结节怎么办?专家告诉你 5 句大实话
成人颅骨变形的原因及治疗方法
重疾险中的身故是指 重疾险都包含什么病种