【設定方法】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が指定した通りに設定されていること確認します。
参考文献
Next.jsの記事Nextjs
- article
Next.jsとEdge Runtimeを組み合わせて超爆速サーバーレス表示を実現する方法
- article
Next.jsでSEO対策を強化するための5つのポイント + アンチパターンの回避策
- article
Next.js × Suspenseを活用した非同期ルーティング体験を実現する方法
- article
next/image vs 外部CDNを徹底比較!Next.js画像最適化戦略を考えてみた
- article
Next.js 「App Router」と「Pages Router」の違いと移行のコツ
- article
Next.js × dotenv-expandを使って環境変数を入れ子で柔軟に管理する方法
- article
どっちを使うべき?TypeScriptのtype(型エイリアス)とinterfaceの違いと使い分け
- article
TypeScript 5.8 で強化された型推論!その裏で潜む 落とし穴と回避策
- article
【早見表】TypeScript Generics(ジェネリクス)の使用例と記法まとめ
- article
開発AIエディタ比較 Github Copilot vs Cursor vs Cline vs devin!それぞれの特徴や料金の違いを比較してみた
- article
【2025年5月版 早見表】TypeScript 5.7 tsconfig.jsonの主要オプションのまとめ
- article
【対処法】Cursorで発生する「Connection failed. If the problem persists ...」エラーの原因と対応