AngularアプリをCloudflare Pagesでホスティングする手順
2023年06月03日 土曜日 09時00分静的なファイルをホスティングする際には、色々と選択肢がありますが、私はCloudflareが好きなので、Cloudflare Pagesを利用しています。
そのため、タイトルの通り、AngularアプリをCloudflare Pagesでホスティングする手順を自分用のメモとして記録しておきます。
間違いがあれば、コメント頂ければと思います。
環境
名称 | バージョンなど |
---|---|
OS | macOS Monterey 12.6.6 |
node | 18.14.2 |
Angular | 16.0.2 |
前提
- Angular CLIをインストールしていること。
リポジトリなど
- https://github.com/teruhirokomaki/angular-cloudflare-iemie3
- https://angular-cloudflare-iemie3.pages.dev
手順(作業記録)
GitHubでリポジトリを作成する
data:image/s3,"s3://crabby-images/c1546/c15469ec9eb73a5ce44ff64f1a601606040f35e5" alt="GitHub"
リポジトリをクローンする
ghq get [email protected]:teruhirokomaki/angular-cloudflare-iemie3.git
cd ~/go/src/github.com/teruhirokomaki/angular-cloudflare-iemie3
(ins) teruhiro:~/go/src/github.com/teruhirokomaki/angular-cloudflare-iemie3 $ ls -la
total 8
drwxr-xr-x 4 teruhiro staff 128 Jun 3 04:49 .
drwxr-xr-x 38 teruhiro staff 1216 Jun 3 04:41 ..
drwxr-xr-x 12 teruhiro staff 384 Jun 3 04:41 .git
-rw-r--r-- 1 teruhiro staff 27 Jun 3 04:41 README.md
Angularのワークスペースを作成する
- Angular 日本語ドキュメンテーション - ng new
- ワークスペースを作成します。
ng new my-app --standalone --skip-git
(ins) teruhiro:~/go/src/github.com/teruhirokomaki/angular-cloudflare-iemie3 $ ng new my-app --standalone --skip-git
? Would you like to add Angular routing? Yes
? Which stylesheet format would you like to use? SCSS [ https://sass-lang.com/documentation/syntax#scss ]
Standalone application structure is new and not yet supported by many existing 'ng add' and 'ng update' integrations with community libraries.
CREATE my-app/README.md (1059 bytes)
CREATE my-app/.editorconfig (274 bytes)
CREATE my-app/.gitignore (548 bytes)
CREATE my-app/angular.json (3065 bytes)
CREATE my-app/package.json (1037 bytes)
CREATE my-app/tsconfig.json (901 bytes)
CREATE my-app/tsconfig.app.json (263 bytes)
CREATE my-app/tsconfig.spec.json (273 bytes)
CREATE my-app/.vscode/extensions.json (130 bytes)
CREATE my-app/.vscode/launch.json (470 bytes)
CREATE my-app/.vscode/tasks.json (938 bytes)
CREATE my-app/src/main.ts (250 bytes)
CREATE my-app/src/favicon.ico (948 bytes)
CREATE my-app/src/index.html (291 bytes)
CREATE my-app/src/styles.scss (80 bytes)
CREATE my-app/src/app/app.component.scss (0 bytes)
CREATE my-app/src/app/app.component.html (23115 bytes)
CREATE my-app/src/app/app.component.spec.ts (888 bytes)
CREATE my-app/src/app/app.component.ts (368 bytes)
CREATE my-app/src/app/app.config.ts (228 bytes)
CREATE my-app/src/app/app.routes.ts (77 bytes)
CREATE my-app/src/assets/.gitkeep (0 bytes)
✔ Packages installed successfully.
data:image/s3,"s3://crabby-images/17274/17274135e0f23dc7f7b0c8d4f4e2c1ffa1ebb730" alt="terminal"
ワークスペースを確認する
(ins) teruhiro:~/go/src/github.com/teruhirokomaki/angular-cloudflare-iemie3 $ cd my-app/
(ins) teruhiro:~/go/src/github.com/teruhirokomaki/angular-cloudflare-iemie3/my-app $ ls -la
total 936
drwxr-xr-x 14 teruhiro staff 448 Jun 3 04:49 .
drwxr-xr-x 5 teruhiro staff 160 Jun 3 04:49 ..
-rw-r--r-- 1 teruhiro staff 274 Jun 3 04:49 .editorconfig
-rw-r--r-- 1 teruhiro staff 548 Jun 3 04:49 .gitignore
drwxr-xr-x 5 teruhiro staff 160 Jun 3 04:49 .vscode
-rw-r--r-- 1 teruhiro staff 1059 Jun 3 04:49 README.md
-rw-r--r-- 1 teruhiro staff 3065 Jun 3 04:49 angular.json
drwxr-xr-x 573 teruhiro staff 18336 Jun 3 04:49 node_modules
-rw-r--r-- 1 teruhiro staff 445654 Jun 3 04:49 package-lock.json
-rw-r--r-- 1 teruhiro staff 1037 Jun 3 04:49 package.json
drwxr-xr-x 8 teruhiro staff 256 Jun 3 04:49 src
-rw-r--r-- 1 teruhiro staff 263 Jun 3 04:49 tsconfig.app.json
-rw-r--r-- 1 teruhiro staff 901 Jun 3 04:49 tsconfig.json
-rw-r--r-- 1 teruhiro staff 273 Jun 3 04:49 tsconfig.spec.json
data:image/s3,"s3://crabby-images/4b477/4b477a4718f9eb48b9cdb3576a50abc3c0bfc923" alt="editor"
environment.ts
ファイルを作成する
- Angular - Building and serving Angular apps
- Angular 15 CLI does not create environments folder when creating an angular project via ng new - Stack Overflow
- environmentを作成します。
ng g environments
(ins) teruhiro:~/go/src/github.com/teruhirokomaki/angular-cloudflare-iemie3/my-app $ ng g environments
CREATE src/environments/environment.ts (31 bytes)
CREATE src/environments/environment.development.ts (31 bytes)
UPDATE angular.json (3290 bytes)
data:image/s3,"s3://crabby-images/a706c/a706c05bb7e218d41d91b1b01d8ce352dcf940b9" alt="editor"
.nvmrc
ファイルを作成する
- Cloudflareでビルドする際に、nodeのバージョンを指定するため、
.nvmrc
ファイルを作成します。node -v > .nvmrc
(ins) teruhiro:~/go/src/github.com/teruhirokomaki/angular-cloudflare-iemie3/my-app $ echo "v18.14.0" > .nvmrc
(ins) teruhiro:~/go/src/github.com/teruhirokomaki/angular-cloudflare-iemie3/my-app $ cat .nvmrc
v18.14.0
もしくは…
(ins) teruhiro:~/go/src/github.com/teruhirokomaki/angular-cloudflare-iemie3/my-app $ node -v > .nvmrc
(ins) teruhiro:~/go/src/github.com/teruhirokomaki/angular-cloudflare-iemie3/my-app $ cat .nvmrc
v18.14.2
ng serve
して確認する
/Users/teruhiro/.n/bin/npm run start
> [email protected] start
> ng serve
✔ Browser application bundle generation complete.
Initial Chunk Files | Names | Raw Size
vendor.js | vendor | 2.26 MB |
polyfills.js | polyfills | 328.93 kB |
styles.css, styles.js | styles | 226.83 kB |
main.js | main | 46.29 kB |
runtime.js | runtime | 6.51 kB |
| Initial Total | 2.86 MB
Build at: 2023-06-02T20:40:40.859Z - Hash: df110a776fdfceac - Time: 1335ms
** Angular Live Development Server is listening on localhost:4200, open your browser on http://localhost:4200/ **
✔ Compiled successfully.
data:image/s3,"s3://crabby-images/d8764/d8764204fa1462f82f55121bd589befafd801895" alt="editor"
data:image/s3,"s3://crabby-images/bed37/bed37a6b268033a489106310a96de1a6b1a7f816" alt="localhost:4200"
ng build
して確認する
/Users/teruhiro/.n/bin/npm run build
> [email protected] build
> ng build
✔ Browser application bundle generation complete.
✔ Copying assets complete.
✔ Index html generation complete.
Initial Chunk Files | Names | Raw Size | Estimated Transfer Size
main.51718165e0e5f094.js | main | 189.02 kB | 52.45 kB
polyfills.4aecfb127e78c0d2.js | polyfills | 32.98 kB | 10.64 kB
runtime.771c5fa6dd11d129.js | runtime | 890 bytes | 510 bytes
styles.ef46db3751d8e999.css | styles | 0 bytes | -
| Initial Total | 222.88 kB | 63.59 kB
Build at: 2023-06-02T20:41:21.238Z - Hash: e0b52fb5329453f9 - Time: 1492ms
Process finished with exit code 0
data:image/s3,"s3://crabby-images/122d2/122d23dc031b55620f0c39ab416050efdaafda6a" alt="ng build"
data:image/s3,"s3://crabby-images/6906d/6906d2be9e0c9fd698ffd7ea50f2b72d2fd018df" alt="dist"
プッシュする
data:image/s3,"s3://crabby-images/56d42/56d4235fab5d53491d4db41216be7b3fc0af4c9a" alt="push"
data:image/s3,"s3://crabby-images/0323b/0323bcd30d19577dd4e9fab1bd5c6bcd4b704bda" alt="GitHub"
Cloudflareにログインし、アプリケーションを作成する
data:image/s3,"s3://crabby-images/c4254/c4254bd38324f5cbd85833966fde3aa8fc137853" alt="Cloudflare"
リポジトリを選択する
data:image/s3,"s3://crabby-images/ed305/ed3057f3489611893f4e6e5dcfd4c6b8d97570ca" alt="Cloudflare"
ビルドの設定をする
今回の構成の場合、図のようになります。
設定 | 値 |
---|---|
ビルドコマンド | npx ng build |
ビルド出力ディレクトリ | /dist/my-app/ |
ルートディレクトリ | /my-app/ |
data:image/s3,"s3://crabby-images/ab6d1/ab6d1328141eed847dc6b3eb6c359a29ebef01aa" alt="Cloudflare"
デプロイする
data:image/s3,"s3://crabby-images/0e7c5/0e7c5bcf3c1dd2503697dbc0cd44dc9595ebfffd" alt="Cloudflare"
data:image/s3,"s3://crabby-images/56b37/56b3792dd5aa9d932adc41ab16ff737c3c86c071" alt="Cloudflare"
プロジェクトページに戻る
data:image/s3,"s3://crabby-images/40f12/40f12ed63dfd27946f40bd58d4e7a86d7d196b82" alt="Cloudflare"
URLにアクセスする
data:image/s3,"s3://crabby-images/92f30/92f309aafe53f8aea87b50f168d4744f74d34e97" alt="Cloudflare"
コードを変更して、プッシュする
data:image/s3,"s3://crabby-images/0a2b1/0a2b15f6fd8e8b440c6c728d435025fb65001965" alt="git push"
data:image/s3,"s3://crabby-images/2728a/2728a921eb87a2ab3757f6dec84168fbf3e99e8a" alt="Cloudflare"
アプリをリロードして、変更箇所を確認する
data:image/s3,"s3://crabby-images/b58e2/b58e264489ff06ad1592489bb310648a92d0e0e8" alt="localhost:4200"
おわり
- 自分用のメモなので、説明が不足しているかもしれませんが、余裕があれば、更新します。
- お役に立てたようでしたら、記事をシェアして頂けると、嬉しいです。