【設定方法】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が指定した通りに設定されていること確認します。
参考文献
articleNext.js の キャッシュ無効化設計:タグ・パス・スケジュールの 3 軸でコントロール
articleNext.js Metadata API 逆引き:`robots`/`alternates`/`openGraph`/`twitter` の記入例
articleNext.js を Bun で動かす開発環境:起動速度・互換性・落とし穴
articleNext.js Edge Runtime vs Node Runtime:TTFB・コールドスタート・コストを実測検証
articleNext.js の Route Handlers で multipart/form-data が受け取れない問題の切り分け術
articleNext.js Server Components 時代のデータ取得戦略:fetch キャッシュと再検証の新常識
articleJavaScript 非同期エラー完全攻略:Unhandled Rejection を根絶する設計パターン
article【早見表】JavaScript MutationObserver & ResizeObserver 徹底活用:DOM 変化を正しく監視する
articleJavaScript Drag & Drop API 完全攻略:ファイルアップロード UI を最速で作る
articleJavaScript structuredClone 徹底検証:JSON 方式や cloneDeep との速度・互換比較
articleJavaScript 時刻の落とし穴大全:タイムゾーン/DST/うるう秒の実務対策
articleJavaScript Web Animations API:滑らかに動く UI を設計するための基本と実践
articleWebSocket Close コード早見表:正常終了・プロトコル違反・ポリシー違反の実務対応
articleStorybook 品質ゲート運用:Lighthouse/A11y/ビジュアル差分を PR で自動承認
articleWebRTC で高精細 1080p/4K 画面共有:contentHint「detail」と DPI 最適化
articleSolidJS フォーム設計の最適解:コントロール vs アンコントロールドの棲み分け
articleWebLLM 使い方入門:チャット UI を 100 行で実装するハンズオン
articleShell Script と Ansible/Make/Taskfile の比較:小規模自動化の最適解を検証
blogiPhone 17シリーズの発表!全モデルiPhone 16から進化したポイントを見やすく整理
blogGoogleストアから訂正案内!Pixel 10ポイント有効期限「1年」表示は誤りだった
blog【2025年8月】Googleストア「ストアポイント」は1年表記はミス?2年ルールとの整合性を検証
blogGoogleストアの注文キャンセルはなぜ起きる?Pixel 10購入前に知るべき注意点
blogPixcel 10シリーズの発表!全モデル Pixcel 9 から進化したポイントを見やすく整理
blogフロントエンドエンジニアの成長戦略:コーチングで最速スキルアップする方法
review今の自分に満足していますか?『持たざる者の逆襲 まだ何者でもない君へ』溝口勇児
reviewついに語られた業界の裏側!『フジテレビの正体』堀江貴文が描くテレビ局の本当の姿
review愛する勇気を持てば人生が変わる!『幸せになる勇気』岸見一郎・古賀史健のアドラー実践編で真の幸福を手に入れる
review週末を変えれば年収も変わる!『世界の一流は「休日」に何をしているのか』越川慎司の一流週末メソッド
review新しい自分に会いに行こう!『自分の変え方』村岡大樹の認知科学コーチングで人生リセット
review科学革命から AI 時代へ!『サピエンス全史 下巻』ユヴァル・ノア・ハラリが予見する人類の未来