quest3 を入手したあたりから webxr するべく web 周りを弄っているのだが芋蔓式に手が拡がっていき、 延々と ssg を作り替えているようになってきました。 ついに、前から気になっていた svelte まで来ました。 せっかく svelte にしましたし、webgl とかをサイトに組み込むぞー。

最初は手が拡がらないように typescript を避けて comment に jsdoc の型情報を書いていました。 確か xrterm.jswebxr 向けに改造するのに import を解りやすくするためにライブラリ全体を esmodule 化する作業(tsmts に書き替え)をやったのだけど、この時の開発体験がよくて vite + typescript ならいけると確信しました。

webxr を中心に進めたところ、 WebRTCReact が射程に入りました。 この辺で、httpswebsocket が必須になってサンプルも docker を使っているものが多くなってきました。electronexpress を試行錯誤したのだけど、frontend と比べてどうも vite の使い勝手が良くないと感じます。deno も下見しましたが、backendjs をやめて go にしようという判断になりました。frontend と backend がコードや tsconfig.json を共有するのが良くない感じでした。

webgl は、A-Frame を使うつもりで進めたのだけど、 A-Frameesmodule 化されておらず、class生成が普通の class でない昔の prototype 的な実装であるため、今後もされなさそうなので候補から外しました。次に Three.jsReact ラッパー react-three-fiber を使う方向で進めて、そのために素の React を使う感じの minista を使っていたのだけど、sveltevite を主に使っていることを発見したので、svelte にも手を出してみました。 svelte の初期化や状態管理は、React の hook より簡単そうなので、three-js と組みあわせたときの使い勝手に期待しています。なので three-js の svelte ラッパーを採用予定。

Next.js も下見したのだけど、turbopack は苦手な webpack の気配がしますので svelte に行くことにしました。あと、名前を良く目にする tailwind も取りいれてみました。 さらに storybook も取り入れています。 おもしろ storybookbabylon.js らしい。

手を拡げすぎで大変だと思っていたのですが、 使う要素が定まってきました。

  • vite

  • typescript

  • svelte

  • tailwind

  • storybook

  • three.js

  • WebXR

  • WebRTC

  • websocket

  • https

  • go

広いデス。

こういうのを作ろうとしています。

記事とか repository の一覧

参考

Next.jsでブログをつくった