こちらで作成したJSのトランスパイルツールをGitHub上に配置しました。
その使い方について説明していきます。
node.jsがインストールされていること。 もし、まだの方はこの記事を参考にしてください。
git clone https://github.com/wadakatu/js-build-tool.git
クローン終了後、js-build-toolのディレクトリが存在していればOKです。
以降の作業は、全て「js-transpile-tool」ディレクトリ内で行います。
cd js-transpile-tool
npm install
srcフォルダの中にトランパイルしたいJSファイルを設置してください。
ファイルの数は、単数でも複数でも大丈夫です。
以下のコマンドでトランパイルが実行できます。
npm run build -- --env filename=bundle
やっていることは下記の通りです。
- ESLintでJS構文チェック
- 構文にエラーがなければ、ES5にトランスパイル
- トランスパイルしたファイルをdistフォルダに出力
構文チェックでエラーがあった場合は、処理が中断されます。(トランスパイル後のJSファイルは生成されない)
ファイル名は、任意の値に変更してください。 拡張子は必要ないです。
distフォルダ内に、JSファイルが1つ作成されていればOKです。
ファイル名は、先ほどトランスパイル実行時に入力した値。(今回だとbundle.js)
この作成されたファイルを任意プロジェクトの任意ディレクトリ配下に設置してください。
あとは、htmlファイルにそのJSファイルを読み込むScriptタグを書けば完了です。
初めての方向けに、テスト用JSファイルを用意してあります。
フォルダ構成:js-transpile-tool/test/src <-- トランスパイル前
js-transpile-tool/test/dist <-- トランスパイル後
js-transpile-tool/test/src直下には、「app.js」と「cats.js」が配置されています。
これらは、cats.jsで定義した配列の内容をapp.jsで読み込んで、
コンソール上に出力するというシンプルなJSです。
node app.js
[‘tama’, ‘kuro’, ‘tora’]
上記のように出力されるはずです。
今回は、この2つのファイルをトランスパイルし1つにまとめてみましょう。
トランスパイル前とトランスパイル後で、出力内容が一致すればOKです。
それではトランスパイルを実行してみましょう。
npm run test -- --env filename=hogehoge
下記のようなエラーが出ると思います。
$ npm run test -- --env filename=hogehoge
> js-build-tool@1.0.0 test
> eslint --no-eslintrc --c .test-eslint.json ./test/src/*.js && webpack --config=webpack.config.test.js “--env” “filename=hogehoge”
/Users/hogehoge/js-build-tool/js-transpile-tool/test/src/cats.js
1:45 error Missing semicolon semi
×: 1 problem (1 error, 0 warnings)
1 error and 0 warnings potentially fixable with the `--fix` option.
このエラーは、「末尾のセミコロンがない」ことが原因です。
cats.js内のコード末尾にセミコロンを追加しましょう。
export const cats = [‘tama’, ‘kuro’, ‘tora’];
npm run test -- --env filename=hogehoge
下記のような表示が出て、トランスパイルが成功します。
$ npm run test -- --env filename=hogehoge
> js-build-tool@1.0.0 test
> eslint --no-eslintrc --c .test-eslint.json ./test/src/*.js && webpack --config=webpack.config.test.js “--env” “filename=hogehoge”
asset hogehoge.js 480 bytes [emitted] [minimized] (name: main)
runtime modules 416 bytes 2 modules
cacheable modules 95 bytes
./test/src/app.js 52 bytes [built] [code generated]
./test/src/cats.js 43 bytes [built] [code generated]
webpack 5.45.1 compiled successfully in 767 ms
test/distフォルダ直下に移動して、トランスパイル後のJSファイルを実行してみましょう。
//フォルダ移動
cd test/dist
//JSファイル実行
node hogehoge.js
トランスパイル前と出力内容が一致すれば成功です。
[‘tama’, ‘kuro’, ‘tora’]