【設定方法】Next.jsでterser-webpack-pluginを設定し本番ビルド時にコメントとconsole.logを削除するサンプルコード
Next.jsで作ったアプリケーションの
コメント
とconsole.log
を本番ビルド時に削除したかったため
terser-webpack-plugin
をインストールして設定したので
手順としてやり方をメモします。
terser-webpack-pluginとは
tenrserを利用して
JavaScriptを圧縮するWebpackのプラグインになります。
UglifyJSが非推奨
もともとuglifyjs-webpack-pluginというプラグインもあったのですが
非推奨になったようなので今後の選択肢としてtenrserを利用します。
環境
- React 17.0.2
- Next.js 7.0
必要なパッケージのインストール
terser-webpack-pluginをインストール
terser-webpack-plugin
をyarn
コマンドでインストールします。
※ npmでインストールする場合は適宜置き換えてください。
terminal$ yarn add -D terser-webpack-plugin
webpackをインストール
next.js
はwebpackが内包されているため
設定を変更する場合は別途インストールします。
terminal$ yarn add -D webpack
dotenvをインストール
本番判定をする際に環境変数を .env
で管理していたため
dotenv
をインストールしています。
mode
やNODE_ENVを
を利用している場合は適宜置き換えてください。
terminal$ yarn add -D dotenv
.envの設定
.env
に環境を記載します。
本番用は下記のようにSTAGE変数へproduction
を設定しています。
.env
# 本番
STAGE=production
next.config.jsの設定
全体のコード
先に全体のコードを記載します。 解説はこの後に記載させていただいています。
next.config.jsconst path = require("path");
const TerserPlugin = require('terser-webpack-plugin');
const dotenv = require("dotenv");
const webpack = require("webpack");
dotenv.config({ path: path.resolve(".env") });
module.exports = webpack(config, options) {
if (process.env.STAGE && process.env.STAGE === 'production'){
config.optimization.minimize = true;
config.optimization.minimizer = [
new TerserPlugin({
terserOptions: {
compress: { drop_console: true }
},
extractComments: "all"
})
];
}
return config;
}
コードの解説
インストールしたパッケージの読み込み
requireでインストールしたパッケージを読み込みます。
next.config.jsconst path = require("path");
const TerserPlugin = require('terser-webpack-plugin');
const dotenv = require("dotenv");
const webpack = require("webpack");
dotenvの読み込み
.env
に記載した変数を読み込みます。
next.config.jsdotenv.config({ path: path.resolve(".env") });
アクセスは process.env.変数名
で取得できます。
webpackの設定に追加する
config
の引数からnext.js
で隠蔽されている設定が取得できるため
ここに terser-webpack-plugin
の設定を追記します。
next.config.jswebpack(config, options) {
console.log(config);
// webpackの設定が確認できる
}
terser-webpack-pluginの設定
コンソールログの削除とコメント削除を設定しています。
コンソールログ削除
yamlterserOptions: {
compress: { drop_console: true }
}
コメント削除するオプション
LICENCE 情報を残してその他のコメントを削除します。
css{
extractComments: "all"
}
プラグインの設定
next.config.jsconfig.optimization.minimize = true;
config.optimization.minimizer = [
new TerserPlugin({
terserOptions: {
compress: { drop_console: true }
},
extractComments: "all"
})
];
オプションについて詳しくはGithub|Options|webpack-contrib/terser-webpack-pluginをご確認ください。
再ビルド・起動して確認
本番用のビルド・起動を実行して確認します。
ruby$ yarn next build && yarn next start
ビルド・起動が完了したらアプリケーションを開いて
aliasが指定した通りに設定されていること確認します。
参考文献
記事Article
もっと見る- article
Dockerの利用していないゴミを掃除しディスクスペースを解放するいくつかのやり方を紹介
- article
Next.js のバンドルサイズを可視化する@next/bundle-analyzer の紹介
- article
VSCodeでTypescriptファイルのimport補完で相対パスではなくエイリアスするための設定
- article
UUIDより短いユニークなIDを生成できるnpmライブラリnanoidの使い方
- article
【解決方法】TypeScript発生したTS2564 エラーの対処
- article
express で IP を取得する際などに利用する req.connection 非推奨(deprecated)の対処