🍅

Astro製サイトのランタイムをBunに移行した

そのほか画像最適化・リンクカードなど

ごきげんよう。そしてお久しぶり。このサイトの技術構成に関して、前回の記事から以下三点の更新があったので紹介する。

Bunの採用

Node.js / pnpmに代わり、ランタイム / パッケージマネージャにBun採用した。速い(らしい)。エンジンがV8じゃないJavaScriptCore)。TypeScriptを直接(追加パッケージなしで)実行できる。いいことばかり。

Say goodbye to Node: Bun migration by haxibami · Pull Request #373 · haxibami/haxibami.net
Limitations Wrangler cannot run on bun runtime (with bunx --bun), until bun implements performance.markResourceTiming (Implement performance.markResourceTiming oven-sh/bun#8867) 🐛 BUG: Error when...
github.com
Say goodbye to Node: Bun migration by haxibami · Pull Request #373 · haxibami/haxibami.net

移行にあたってつまづいた点はZennのスクラップまとめた。必要なだいたいの処理は完全にBunのランタイムで--bunオプション付きで)実行できるが、WranglerでCloudflareにデプロイする処理だけはうまくいかなかった。いつか直るといいね。

画像処理の簡素化・レスポンシブ対応

以前の実装では<Image />コンポーネントを使い、なにやらガタガタと自前で画像をimportする処理を書いたが、Astro 4.2の変更伴って不要になった。より簡単に、remarkプラグインで画像ノードにいくつかのパラメータ(=<Image />オプション)を渡しておけば、その通りに画像を最適化してくれる。これに関連して以下の二つのプラグインを書いた。両者あわせて、パラメータの受け渡しに加え、画像読み込み待ちのプレースホルダーの取得なども行っている。

ちなみに「独自の画像コンポーネントに置き換え」とあるが、以前の実装で行っていた<img>から<Image />への置き換えとは異なるあくまで画像の親要素(Markdownの文法上、独立した画像は必ず<p>要素を親に持つ)に着目し、ざっくり言えば<p><slot /></p><figure><slot /></figure>置き換える処理を行っている。1 2

リンクカード内の画像の取り扱い変更

以前の実装では、リンクカード内のOG画像はすべてbase64形式で埋め込まれていたが、この法にはドキュメント本体のサイズが肥大化するという問題があった(完全に見落としていた)。代わって、画像が要求される度にpublic/.cache/embed以下にキャッシュを作る針に変更した。おそらくはもっとよい法もあるのだろうが……

脚注

  1. まさにここで<slot />使うのが今回のミソともいえる。このおかげで、Astroが内部で<img>から<Image />置き換えている部分には一切手を触れずに済む。

  2. 厳密には、rehype-astro-image-figure <p><figure>変更したうえで、その<figure><slot /></figure><AstroImage><slot /></AstroImage>置き換えている。