From 741500c60303eed7c4a57750e8b3337b60291c98 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ovidiu=20Chereche=C8=99?= Date: Tue, 3 Jan 2017 20:06:55 +0200 Subject: [PATCH] Warn about webpack loaders (#638) --- README.md | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/README.md b/README.md index f043ac27..5f9bae77 100644 --- a/README.md +++ b/README.md @@ -483,8 +483,6 @@ module.exports = { In order to extend our usage of `webpack`, you can define a function that extends its config via `next.config.js`. -The following example shows how you can use [`react-svg-loader`](https://github.com/boopathi/react-svg-loader) to easily import any `.svg` file as a React component, without modification. - ```js // This file is not going through babel transformation. // So, we write it in vanilla JS @@ -492,14 +490,16 @@ The following example shows how you can use [`react-svg-loader`](https://github. module.exports = { webpack: (config, { dev }) => { - config.module.rules.push({ test: /\.svg$/, loader: 'babel!react-svg' }) - - // Important: return the modified config +    // Perform customizations to config +     +    // Important: return the modified config return config } } ``` +*Warning: Adding loaders to support new file types (css, less, svg, etc.) is __not__ recommended because only the client code gets bundled via webpack and thus it won't work on the initial server rendering. Babel plugins are a good alternative because they're applied consistently between server/client rendering (e.g. [babel-plugin-inline-react-svg](https://github.com/kesne/babel-plugin-inline-react-svg)).* + ### Customizing babel config In order to extend our usage of `babel`, you can simply define a `.babelrc` file at the root of your app. This file is optional.