ビルドとは
人間が読み書きしやすいように設計されたプログラミング言語で書いたソースコードを、機械が読みやすい(素早く読み込める) ように変換することです。
ビルドとは、組み立てる、建てる、築く、作り上げる、などの意味を持つ英単語。ソフトウェアの分野では、プログラミング言語で書かれたソースコードなどを元に実行可能ファイルや配布パッケージを作成する処理や操作のこと。
似た用語に コンパイル
、トランスパイル
がありますが、基本的な違いとして成果物が異なります。コンパイルはソースコードから直接実行可能ファイルを生成し、トランスパイルはソースコードから新しいコードを生成します。
JavaScriptのビルド
そもそも JavaScript はスクリプト言語であり、ブラウザ上で動くコードとは別に、サーバー上で動かすことも可能です。 JavaScript を使えばフロントエンドアプリも WebAPI といったサーバー開発、 CLI アプリの開発も行えます。
ブラウザであれば、 js ファイルに処理を書き、 HTML ファイルの script タグから読み込むことで利用できます。
...
<button id="my-button">クリック</button>
...
<script src="main.js"></script>
...
const button = document.getByElementById("my-button");
button.addEventListener('click', () => {
/* 処理の内容 */
});
上記のようなコードはコンパイルをしなくても動かせます。
では、なぜフロントエンド開発にビルド・コンパイルをする必要があるのかを解説していきます。
bundle
複数のファイルをまとめて 1 つのファイルにすることを bundle と言います。
bundle をする理由としましては、ブラウザからアプリケーションを使うときに js ファイルをダウンロードします。このときに、ファイル数が少なければダウンロード時間が短く住むため、パフォーマンスの為に bundle を行います。
あらかじめ 1 つのファイルにまとめて書いてしまっては、可読性・保守性が低くなることは目に見えています。なので、 bundle を行うことで、書くときはエンジニアが読み書きしやすいように書いて、本番環境で実行するときはユーザーが使いやすい(処理が素早い)ようにしてくれます。
トランスパイル
JavaScript を実行する各種ブラウザも日に日に開発が進められ、新しい機能を実装していきます。
しかし、それぞれ別の団体が実装しているので Chrome の最新版で使える JavaScript の機能を firefox では使えない可能性があります。
また、新しい JavaScript の機能が古いブラウザでは使えないといったこともあります。
そのような差異を吸収するために、トランスパイルを行います。
トランスパイルとは、ソースコードを別のソースコードに変換することです。最新のコードを解析し、古い構文を使って書き換えることで、古いエンジンでも動作するようにできます。
なので新しい JavaScript の機能を古いブラウザでも使いたい場合、一度古いブラウザでも動作する構文に書き換えることで可能にします。その作業をトランスパイルすると言います。
JSX
react でフロントエンドを書くときに JSX という構文を使います。見た目は HTML に近いですが、中身は単なる JavaScript です。しかし、JSX 構文はそのままで動作しませんし、ブラウザで読み込むこともできません。
babel や rollup を使って JSX 構文を解析し、 ブラウザで動作する JavaScript のコードへとトランスパイルできます。
babel.jsの web サイトで実際に触ってみることもできます。
const Todos = (props) => {
return (
<div>
<ul>
{props.todos.map((todo) => (
<li key={todo.id}>{todo.titile}</li>
))}
</ul>
</div>
)
}
import { jsx as _jsx } from "react/jsx-runtime";
const Todos = props => {
return /*#__PURE__*/_jsx("div", {
children: /*#__PURE__*/_jsx("ul", {
children: props.todos.map(todo => /*#__PURE__*/_jsx("li", {
children: todo.titile
}, todo.id))
})
});
};
このようにコードが変換されます。
minify
ファイルを圧縮することです。minify を行うことでファイルサイズを縮小させ、ページの表示速度を向上させることができます。
改行やスペース、インデントなどコードを書く・読む際には絶対に必要な要素を省き人間よりもマシンに素早く読ませるコードへと変換します。
UglyJS の web ページで試すことができます。
jsxファイルをビルドする
jsx が書かれたファイルをビルドして使えるようになるまでに、どのような手順を踏むかを説明していきます。
※ 特定のライブラリのケースというよりは一般的にこうビルドされるというイメージを持っていただけたらなと思います。
- jsx ファイルをトランスパイル
-
.jsx
ファイル群から.js
ファイル群へ
- ファイル群を bundle する
- 複数の
.js
ファイルからbundle.js
といった複数ファイルがひとまとめになったファイルへ
- ファイルを minify する
- ひとまとめになった
.js
ファイルから余白や改行・インデントを取り除く