GoogleAnalyticsの検証をしたく、ホスティングする必要が生じたので簡単に無料でできるGithuPagesを試してみます。
React×TypeScriptの環境で行っています。
Viteを利用しているので、適宜ビルドの出力先のディレクトリ名を読み替えてください。
手順
コマンド、package.jsonの修正内容はまとめて手順の後ろに記載しています。
- Repositoryの作成(Public)
- Reactプロジェクトに
gh-pages
をインストール -
package.json
にhomepageを追記 -
package.json
のscriptに追記 -
vite.config..ts
に追記 - mainブランチにpush
- デプロイ(ここで自動でブランチ作成される)
- GitHubのリポジトリの設定(Pages)を変更
npm install gh-pages --save-dev
package.json
"homepage": "https://<github_userName>.github.io/<repository_name>"
package.json
"script": {
"predeploy": "npm run build",
"deploy": "gh-pages -d dist" // {dist | build} ビルド出力先に読み替え必要
}
vite.config.ts
export default defineConfig({
plugins: [react()],
base: '/<repository_name>/'
})
npm run deploy
追加設定
React Router
などのルーティングライブラリを使用している場合は、追加の設定が必要になります。
basenameをGithubPagesと一致させてあげます。
GithubActionを用いた自動デプロイ
プロジェクトルートに.github/workflows/deploy.yml
を作成
.github/workflows/deploy.yml
name: vite-app-deploy
on:
push:
branches:
- main
jobs:
build-and-deploy:
runs-on: ubuntu-latest
steps:
- name: Checkout Repository
uses: actions/checkout@v4
- name: Setup Node.js
uses: actions/setup-node@v4
with:
node-version: 18
cache: npm
- name: Install dependencies
run : npm install
- name: Build project
run : npm run build
- name: Deploy to GitHub Pages
uses: JamesIves/github-pages-deploy-action@v4
with:
branch: gh-pages
folder: dist
clean : true
Repositoryの
設定 > Actions > General > Workflow permissions
をRead and write permissions
にh