3.4 KiB
FAQ
Why not a boilerplate or alternative?
Boilerplates are great resources for scaffolding out application-specific code which would be difficult or tedious to generate for every project. Unfortunately many projects also bake in build configuration into this process, causing a lot of duplication. If you need to make a change to your build steps, you are forced to make that change across all your similar projects. Using a preset rather than a boilerplate keeps this process DRY.
Tools like Create React App have been fantastic improvements to the tooling ecosystem, but unfortunately only work on specific environments like React, and do not allow simple extensibility of the build configuration. To answer this, new and similar projects are cropping up to build different types of projects, often duplicating efforts which miss out on the best practices to share with the other project types.
What is the added value versus all the boilerplate projects out there?
The proliferation of boilerplate and meta-packages is one thing we are trying to reduce. These types of projects are great, and do serve a purpose. But what if you wanted to make a configuration change across all your projects? You must make config changes in many places, including the original boilerplate, whereas presets give you the power to confine these changes to a single package. Some of these projects also make a trade-off between ease of set up and black-boxing the configuration. Once you decide to make a configuration change, you are forced to maintain the entire configuration and its dependencies in perpetuity. We believe Neutrino represents a good balance between ease of set up and future extensibility.
Why don't presets use a normal Webpack configuration object instead of the chaining API?
The Webpack configuration works well when it is embedded into a single project, and it is the only configuration file to maintain. Once the configuration is no longer co-located with the project, and needs to be extended or modified across different projects, it becomes very messy to make those modifications.
For example, let's say that a preset instead used the Webpack object configuration and added an instance of the
EnvironmentPlugin
:
config.plugins.push(new webpack.EnvironmentPlugin(['NODE_ENV']));
If you wanted to extend this plugin in your own project to add more environment variables, you would most likely
resort to either adding a new instance of the EnvironmentPlugin
by requiring Webpack yourself, or looping through
Webpack's plugin array, removing the plugin, and re-instantiating it with your own arguments.
config.plugins = config.plugins.map(plugin => {
if (plugin.constructor.name !== 'EnvironmentPlugin') {
return plugin;
}
return new webpack.EnvironmentPlugin([...plugin.keys, ...customEnvironmentVariables]);
});
This forces a much higher maintenance burden on your project, and this is only a very simple example. Modifying loaders created from raw Webpack configuration objects can be much more unwieldy.
Using webpack-chain affords Neutrino the ability to identify and manipulate parts of the configuration without resorting to object and array manipulation hacks, something not currently possible when working with raw Webpack configuration data.