Viteは2020年に発表された新しいフロントエンドのビルドツールです。
https://ja.vitejs.dev/
プレーンなJavaScript(バニラJS)からVue.js・React・Svelteといった流行のフレームワークまで、さまざまな環境で利用できる汎用的なツールです。
jQueryからTypeScript・Reactまで! Viteで始めるモダンで高速な開発環境構築
また、フロントエンドだけのツールとしてだけでなく
バックエンドとの統合も視野に入れられています。
従来のバックエンド(例: Rails, Laravel)を使用してHTMLを配信し、
アセットの配信にViteを使用したい場合は以下を参照してください
背景から書くと長くなりすぎるので、細かいところは話をしつつ、
いったん、調べた時に見つけた参考資料のリンクだけを記載しておきます。
記事の冒頭部をGoogle先生に翻訳してもらった結果が以下の通り
TLDR; ホットリロードで 5800ms (Laravel Mix) から 224ms (Vite⚡️) に!
私たちは何年もLaravel-Mixを使用してきましたが、かなりうまくいっています。
しかし、最近、Inertia.jsを使用してプロジェクトを構築することにしました
(これはすばらしい決断でした)。プロジェクトが成長し始めると、開発はwebpackのコンパイルを待つのが苦痛になりました。
次に、Vite(Vueの作成者であるEvan Youから)を提供することにしました。
その結果は…驚くべきものでした! TwitterでViteをよく見かけますが、
正直なところ、これほどのスピードがあるとは思っていませんでした。Laravel-Mixが遅すぎました。
E2Eテストは壊れやすすぎてコストが高い
PRの時にテストがないと怒られる
テストにコメントを書いてください
expectに対して、何を目的に書いてるのかを明らかにする
関数レベルのテスト
mockが重要
1個の関数で完結していたらテストは悩まずに書けるが、reactとか使っているとその中でさらに依存が、入れ子が・・・となるとDIが必要になってくる。
DIをやってくれるのがJestだとmockと呼ばれている。
mockまでいけるとすごく万能
GUIが関わる、Viewのテスト
Reactの場合はHooksを使う
機能退行(デグレ)を見る
レグレッションテスト
Seleniumとか使うやつ
GitHubActionsだと回しにくいので、playwriteやpuppeteerを使うといい
ヘッドレスブラウザ系
CLIでchromeを立ち上げて、カーソルぐりぐりとかできる
Viewの単位で実際にコンポーネントを呼んで描画パターンを見せてくれる
これに対してスナップショットテストもできる
でも、これは人間が見る用だと思っている
--template-react-ts
だと SSG が最初から組み込みだった。
フロント側から使うサンプルはよくあるけど、GraphQLサーバとバック側の実装がいまいち見えてこない
レスポンスのキャッシュができるらしい?
定義ファイルを作るらしい?
GraphQLスキーマからテーブル構造を画像化してくれるものがある
or
or
By clicking below, you agree to our terms of service.
New to HackMD? Sign up
Syntax | Example | Reference | |
---|---|---|---|
# Header | Header | 基本排版 | |
- Unordered List |
|
||
1. Ordered List |
|
||
- [ ] Todo List |
|
||
> Blockquote | Blockquote |
||
**Bold font** | Bold font | ||
*Italics font* | Italics font | ||
~~Strikethrough~~ | |||
19^th^ | 19th | ||
H~2~O | H2O | ||
++Inserted text++ | Inserted text | ||
==Marked text== | Marked text | ||
[link text](https:// "title") | Link | ||
 | Image | ||
`Code` | Code |
在筆記中貼入程式碼 | |
```javascript var i = 0; ``` |
|
||
:smile: | ![]() |
Emoji list | |
{%youtube youtube_id %} | Externals | ||
$L^aT_eX$ | LaTeX | ||
:::info This is a alert area. ::: |
This is a alert area. |
On a scale of 0-10, how likely is it that you would recommend HackMD to your friends, family or business associates?
Please give us some advice and help us improve HackMD.
Syncing