【設定方法】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
Next.jsの開発中に発生する Warning: Prop `className` did not match. Server: Client: ...の解決策
- 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
JavaScript 開発者必見!TypeScript への移行で得られる 7 つのメリット
- article
javascript関数型で利用できる配列操作メソッドまとめ
- article
【2025年3月版】JavaScript時間操作ライブラリを徹底比較!日付処理の最適解とは?
- article
UUIDより短いユニークなIDを生成できるnpmライブラリnanoidの使い方
- article
【解決策】express-sessionでセッションが保存されない問題の原因と対応
- article
styled-components の特徴と Next.js のプロジェクトへstyled-componentsを導入するまでの手順
- review
もう「なんとなく」で決めない!『解像度を上げる』馬田隆明著で身につけた、曖昧思考を一瞬で明晰にする技術
- review
もう疲れ知らず!『最高の体調』鈴木祐著で手に入れた、一生モノの健康習慣術
- review
人生が激変!『苦しかったときの話をしようか』森岡毅著で発見した、本当に幸せなキャリアの築き方
- review
もう「何言ってるの?」とは言わせない!『バナナの魅力を 100 文字で伝えてください』柿内尚文著 で今日からあなたも伝え方の達人!
- review
もう時間に追われない!『エッセンシャル思考』グレッグ・マキューンで本当に重要なことを見抜く!
- review
プロダクト開発の悩みを一刀両断!『プロダクトマネジメントのすべて』及川 卓也, 曽根原 春樹, 小城 久美子