Custom Webpack Config
Learn how to customize the webpack config used by Next.js
Good to know: changes to webpack config are not covered by semver so proceed at your own risk
Before continuing to add custom webpack configuration to your application make sure Next.js doesn't already support your use-case:
Some commonly asked for features are available as plugins:
In order to extend our usage of webpack
, you can define a function that extends its config inside next.config.js
, like so:
The webpack
function is executed three times, twice for the server (nodejs / edge runtime) and once for the client. This allows you to distinguish between client and server configuration using the isServer
property.
The second argument to the webpack
function is an object with the following properties:
buildId
:String
- The build id, used as a unique identifier between builds.dev
:Boolean
- Indicates if the compilation will be done in development.isServer
:Boolean
- It'strue
for server-side compilation, andfalse
for client-side compilation.nextRuntime
:String | undefined
- The target runtime for server-side compilation; either"edge"
or"nodejs"
, it'sundefined
for client-side compilation.defaultLoaders
:Object
- Default loaders used internally by Next.js:babel
:Object
- Defaultbabel-loader
configuration.
Example usage of defaultLoaders.babel
:
nextRuntime
Notice that isServer
is true
when nextRuntime
is "edge"
or "nodejs"
, nextRuntime
"edge"
is currently for middleware and Server Components in edge runtime only.