使用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中查看进展。此外,还可以手动触发该工作流。
热门推荐
产品经理面试:如何分享你的项目管理经验?
用户体验设计:产品经理必修课
产品经理面试就像找对象?这些技巧让你“脱单”
大厂产品经理面试攻略:从准备到入职的全流程指南
未来产业,让未来照进现实
从瑞丽到攀枝花:681公里绝美自驾之旅
鲫鱼还是只会清蒸吗?今天分享几种鲫鱼的家常做法
穴位埋线疗法:传统针灸的现代创新
历史上真实的孔子,是否"武艺高强"?
气候变化与新兴污染物威胁饮用水安全,专家详解安全饮水五大关键
水表的读数怎么看
秋天的喀纳斯:五彩斑斓的童话世界
冬游喀纳斯:冰雪世界的童话之旅
《方舟:终极移动版》全面优化攻略:从硬件配置到网络设置
《方舟:终极移动版》手机配置全解析:从最低要求到最佳体验
从宜宾到都江堰的详细乘车指南:包括班车、自驾及公共交通方案
上海各类口腔医疗机构诊查费全攻略:公立 vs 私立,一次看个明白
补牙价格分析:不同补牙材料的详细费用对比
洋安新城:建德的绿色生态新地标
建德洋安新城:滨江绿道提升项目即将启动
亚冬会·保障|当好亚冬会媒体服务保障的“大管家”
物联网如何改变我们的生活:智能家居、交通与医疗的未来展望
冰马俑:哈尔滨冰雪大世界的创新力作
香辣黄辣丁
家常版水煮黄辣丁,简单易做,下饭好搭档,不容错过!
如何在PPT中增加数据库图表:从数据准备到优化展示的完整指南
宁波必去景点全攻略:从天一阁到东钱湖,玩转甬城精华
“宁波最in乡村旅游打卡点”出炉 50景带你探索乡野新玩法
医保牙科门诊可以报销吗?口腔医院看牙医保能报销吗?
西安周边观星指南:华山、照金牧场、关山草原,你更Pick哪个?