手摸手带你在github上自动部署应用

现成的可参考仓库:react-steps

  1. 在 github 新建仓库(略
  2. 添加 package.json 文件,提供对应打包命令,如:
json 复制代码
{
  "scripts": {
    "build": "tsc && vite build"
  },
}

不一定是 build,可以自定义,在下面的步骤里对应 build 相应替换即可

  1. 在项目根目录下,新建 .github/workflows/react-build.yml,内容如下:
yaml 复制代码
name: Build and Deploy

on:
  push:
    branches:
      - main

jobs:
  build:
    runs-on: ubuntu-latest

    steps:
    - name: Checkout Repository
      uses: actions/checkout@v2

    - name: Setup Node.js
      uses: actions/setup-node@v2
      with:
        node-version: '16'

    - name: Install Dependencies
      run: npm install

    - name: Build React App with Vite
      run: npm run build

    - name: Deploy to GitHub Pages
      uses: peaceiris/actions-gh-pages@v3
      with:
        github_token: ${{ secrets.GH_TOKEN }}
        publish_dir: ./docs

其中的 ./docs 代表 npm run build 执行后打包出来的文件夹,GH_TOKEN 需要在 github 上来生成和配置,后面会讲到。

  1. github 上操作生成 GH_TOKEN

链接:github.com/settings/to...

  1. 在项目中配置 GH_TOKEN

复制刚生成的 token

在项目目录下,设置这个token

  1. 提交代码到 github
  2. github 会根据 .github/workflows/react-build.yml 文件来进行构建,首次构建完后会自动创建一个 gh-pages 分支,该分支里的代码为 npm run build 生成的目录下的代码以及一个自动生成的 文件 .nojekell 文件

其中的第二步到第六步,对应的是 .github/workflows/react-build.yml 配置中的 jobs 下的 steps。

  1. 配置 github-pages
  1. 在项目中配置在线预览访问地址:

访问的地址格式为:https://用户名.github.io/项目名

  1. 访问静态资源的根目录地址为 https://用户名.github.io 而真正的资源目录为 项目名/ 下,所以在打包时,html 里引入的地址,需要加入项目名,如下:

如果在一个 vite 打包的环境下,则可以在 vite.config.ts 中这样配置

ts 复制代码
import { defineConfig } from 'vite'
import react from '@vitejs/plugin-react'

// https://vitejs.dev/config/
export default defineConfig({
  base: '/react-starter', // 这里配置为 github 对应的项目名
  build: {
    outDir: "docs",
  },
  plugins: [react()],
})

以上,整个自动打包配置就完成了。

相关推荐
JustHappy5 小时前
古法编程秘籍(二):什么是代码模块化?别背概念,把房间收拾明白就够了
前端·后端
小江的记录本5 小时前
【JVM虚拟机】堆内存分代模型:年轻代(Eden+Survivor)、老年代、元空间Metaspace(附《思维导图》+《面试高频考点清单》)
java·前端·jvm·后端·python·spring·面试
weixin_471383035 小时前
图片预解码缓存
前端·浏览器缓存·图片预解码
郑洁文7 小时前
基于网络爬虫的Web敏感信息泄露自动化检测工具
前端·爬虫·网络安全·自动化
郑洁文8 小时前
可视化Web渗透分析工具的设计与实现
前端
罗超驿8 小时前
18.Web API 实战:元素与表单属性的获取和修改
开发语言·前端·javascript
边界条件╝8 小时前
微前端进阶(四)
前端·状态模式
无风听海8 小时前
JSON Web Token(JWT)完全指南
java·前端·json
IT_陈寒9 小时前
Python闭包里藏的这个坑,差点让我加班到凌晨
前端·人工智能·后端
IT_陈寒9 小时前
Java注解空指针?这个坑我踩得莫名其妙
前端·人工智能·后端