Webpack 4 Tutorial: from 0 Conf to Production Mode
webpack 4 is out!
The popular module bundler gets a massive update.
webpack 4, what’s new? A massive performance improvement, zero configuration and sane defaults.
This is a living, breathing introduction to webpack 4. Constantly updated.
You’ll build a working webpack 4 environment by following each section in order. But feel free to jump over the tutorial!
Table of Contents
webpack 4 as a zero configuration module bundler
webpack is powerful and has a lot of unique features but one of its pain point is the configuration file.
Providing a configuration for webpack is not a big deal in medium to bigger projects. You can’t live without one. Yet, for smaller ones it’s kind of annoying, especially when you want to kickstart some toy app.
That’s why Parcel gained a lot of traction.
Here’s the breaking news now: webpack 4 doesn’t need a configuration file by default!
Let’s try that out.
webpack 4: getting started with zero conf
Create a new directory and move into it:
- mkdir webpack-4-quickstart && cd $_
Initialize a package.json by running:
- npm init -y
and pull webpack 4 in:
- npm i webpack --save-dev
We need webpack-cli also, which lives as a separate package:
- npm i webpack-cli --save-dev
Now open up package.json and add a build script:
- "scripts": {
- "build": "webpack"
- }
Close the file and save it.
Try to run:
- npm run build
and see what happens:
- ERROR in Entry module not found: Error: Can't resolve './src' in '~/webpack-4-quickstart'
webpack 4 is looking for an entry point in ./src! If you don’t know what that means go check out my previous article on switching from Gulp to webpack.
In brief: the entry point is the file webpack looks for to start building your Javascript bundle.
In the previous version of webpack the entry point has to be defined inside a configuration file named webpack.config.js.
But starting from webpack 4 there is no need to define the entry point: it will take ./src/index.js as the default!
Testing the new feature is easy. Create ./src/index.js:
- console.log(`I'm a silly entry point`);
and run the build again:
- npm run build
You will get the bundle in ~/webpack-4-quickstart/dist/main.js.
What? Wait a moment. There is no need to define the output file? Exactly.
In webpack 4 there is no need to define neither the entry point, nor the output file.
webpack’s main strength is code splitting. But trust me, having a zero configuration tool speeds things up.
So here is the first news: webpack 4 doesn’t need a configuration file.
It will look in ./src/index.js as the default entry point. Moreover, it will spit out the bundle in ./dist/main.js.
In the next section we’ll see another nice feature of webpack 4: production and development mode.
webpack 4: production and development mode
Having 2 configuration files is a common pattern in webpack.
A tipical project may have:
- a configuration file for development, for defining webpack dev server and other stuff
- a configuration file for production, for defining UglifyJSPlugin, sourcemaps and so on
While bigger projects may still need 2 files, in webpack 4 you can get by without a single line of configuration.
How so?
webpack 4 introduces production and development mode.
In fact if you pay attention at the output of npm run buildyou’ll see a nice warning:
The ‘mode’ option has not been set. Set ‘mode’ option to ‘development’ or ‘production’ to enable defaults for this environment.
What does that mean? Let’s see.
Open up package.json and fill the script section like the following:
- "scripts": {
- "dev": "webpack --mode development",
- "build": "webpack --mode production"
- }
Now try to run:
- npm run dev
and take a look at ./dist/main.js. What do you see? Yes, I know, a boring bundle… not minified!
Now try to run:
- npm run build
and take a look at ./dist/main.js. What do you see now? A minified bundle!
Yes!
Production mode enables all sorts of optimizations out of the box. Including minification, scope hoisting, tree-shaking and more.
Development mode on the other hand is optimized for speed and does nothing more than providing an un-minified bundle.
So here is the second news: webpack 4 introduces production and development mode.
In webpack 4 you can get by without a single line of configuration! Just define the --modeflag and you get everything for free!
webpack 4: overriding the defaults entry/output
I love webpack 4 zero conf but how about overriding the default entry point? And the default output?
Configure them in package.json!
Here’s an example:
- "scripts": {
- "dev": "webpack --mode development ./foo/src/js/index.js --output ./foo/main.js",
- "build": "webpack --mode production ./foo/src/js/index.js --output ./foo/main.js"
- }
webpack 4: transpiling Javascript ES6 with Babel
Modern Javascript is mostly written in ES6.
But not every browser know how to deal with ES6. We need some kind of transformation.
This transformation step is called transpiling. Transpiling is the act of taking ES6 and making it understandable by older browsers.
Webpack doesn’t know how to make the transformation but has loaders: think of them as of transformers.
babel-loader is the webpack loader for transpiling ES6 and above, down to ES5.
To start using the loader we need to install a bunch of dependencies. In particular:
- babel-core
- babel-loader
- babel-preset-env for compiling Javascript ES6 code down to ES5
Let’s do it:
- npm i babel-core babel-loader babel-preset-env --save-dev
Next up configure Babel by creating a new file named .babelrc inside the project folder:
- {
- "presets": [
- "env"
- ]
- }
At this point we have 2 options for configuring babel-loader:
- using a configuration file for webpack
- using --module-bindin your npm scripts
Yes, I know what you’re thinking. webpack 4 markets itself as a zero configuration tool. Why would you write a configuration file again?
The concept of zero configuration in webpack 4 applies to:
- the entry point. Default to ./src/index.js
- the output. Default to ./dist/main.js
- production and development mode (no need to create 2 separate confs for production and development)
And it’s enough. But for using loaders in webpack 4 you still have to create a configuration file.
I’ve asked Sean about this. Will loaders in webpack 4 work the same as webpack 3? Is there any plan to provide 0 conf for common loaders like babel-loader?
His response:
“For the future (after v4, maybe 4.x or 5.0), we have already started the exploration of how a preset or addon system will help define this. What we don’t want: To try and shove a bunch of things into core as defaults What we do want: Allow other to extend”
For now you must still rely on webpack.config.js. Let’s take a look…
webpack 4: using babel-loader with a configuration file
Give webpack a configuration file for using babel-loader in the most classical way.
Create a new file named webpack.config.jsand configure the loader:
- module.exports = {
- module: {
- rules: [
- {
- test: /\.js$/,
- exclude: /node_modules/,
- use: {
- loader: "babel-loader"
- }
- }
- ]
- }
- };
There is no need to specify the entry point unless you want to customize it.
Next up open ./src/index.js and write some ES6:
- const arr = [1, 2, 3];
- const iAmJavascriptES6 = () => console.log(...arr);
- window.iAmJavascriptES6 = iAmJavascriptES6;
Finally create the bundle with:
- npm run build
Now take a look at ./dist/main.js to see the transpiled code.
webpack 4: using babel-loader without a configuration file
There is another method for using webpack loaders.
The --module-bindflag lets you specify loaders from the command line. Thank you Cezar for pointing this out.
The flag is not webpack 4 specific. It was there since version 3.
To use babel-loader without a configuration file configure your npm scripts in package.json like so:
- "scripts": {
- "dev": "webpack --mode development --module-bind js=babel-loader",
- "build": "webpack --mode production --module-bind js=babel-loader"
- }
And you’re ready to run the build.
I’m not a fan of this method (I don’t like fat npm scripts) but it is interesting nonetheless.
webpack 4: setting up webpack 4 with React
That’s easy once you’ve installed and configured babel.
Install React with:
- npm i react react-dom --save-dev
Next up add babel-preset-react:
- npm i babel-preset-react --save-dev
Configure the preset in .babelrc:
- {
- "presets": ["env", "react"]
- }
and you’re good to go!
To test things out you can create a dummy React component in ./src/App.js:
- import React from "react";
- import ReactDOM from "react-dom";
- const App = () => {
- return (
- <div>
- <p>React here!</p>
- </div>
- );
- };
- export default App;
- ReactDOM.render(<App />, document.getElementById("app"));
Next up import the component in ./src/index.js:
- import App from "./App";
and run the build again.
webpack 4: the HTML webpack plugin
webpack needs two additional components for processing HTML: html-webpack-plugin and html-loader.
Add the dependencies with:
- npm i html-webpack-plugin html-loader --save-dev
Then update the webpack configuration:
- const HtmlWebPackPlugin = require("html-webpack-plugin");
- module.exports = {
- module: {
- rules: [
- {
- test: /\.js$/,
- exclude: /node_modules/,
- use: {
- loader: "babel-loader"
- }
- },
- {
- test: /\.html$/,
- use: [
- {
- loader: "html-loader",
- options: { minimize: true }
- }
- ]
- }
- ]
- },
- plugins: [
- new HtmlWebPackPlugin({
- template: "./src/index.html",
- filename: "./index.html"
- })
- ]
- };
Next up create an HTML file into ./src/index.html:
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="utf-8">
- <title>webpack 4 quickstart</title>
- </head>
- <body>
- <div id="app">
- </div>
- </body>
- </html>
run the build with:
- npm run build
and take a look at the ./distfolder. You should see the resulting HTML.
There’s no need to include your Javascript inside the HTML file: the bundle will be automatically injected.
Open up ./dist/index.htmlin your browser: you should see the React component working!
As you can see nothing has changed in regards of handling HTML.
webpack 4 is still a module bundler aiming at Javascript.
But there are plans for adding HTML as a module (HTML as an entry point).
webpack 4: extracting CSS to a file
webpack doesn’t know to extract CSS to a file.
In the past it was a job for extract-text-webpack-plugin.
Unfortunately said plugin does not play well with webpack 4.
According to Michael Ciniawsky:
extract-text-webpack-plugin reached a point where maintaining it become too much of a burden and it’s not the first time upgrading a major webpack version was complicated and cumbersome due to issues with it
mini-css-extract-plugin is here to overcome those issues.
NOTE: Make sure to update webpack to version 4.2.0. Otherwise mini-css-extract-plugin won’t work!
Install the plugin and css-loader with:
- npm i mini-css-extract-plugin css-loader --save-dev
Next up create a CSS file for testing things out:
- /* */
- /* CREATE THIS FILE IN ./src/main.css */
- /* */
- body {
- line-height: 2;
- }
Configure both the plugin and the loader:
- const HtmlWebPackPlugin = require("html-webpack-plugin");
- const MiniCssExtractPlugin = require("mini-css-extract-plugin");
- module.exports = {
- module: {
- rules: [
- {
- test: /\.js$/,
- exclude: /node_modules/,
- use: {
- loader: "babel-loader"
- }
- },
- {
- test: /\.html$/,
- use: [
- {
- loader: "html-loader",
- options: { minimize: true }
- }
- ]
- },
- {
- test: /\.css$/,
- use: [MiniCssExtractPlugin.loader, "css-loader"]
- }
- ]
- },
- plugins: [
- new HtmlWebPackPlugin({
- template: "./src/index.html",
- filename: "./index.html"
- }),
- new MiniCssExtractPlugin({
- filename: "[name].css",
- chunkFilename: "[id].css"
- })
- ]
- };
Finally import the CSS in the entry point:
- //
- // PATH OF THIS FILE: ./src/index.js
- //
- import style from "./main.css";
run the build:
- npm run build
and take a look in the ./dist folder. You should see the resulting CSS!
To recap: extract-text-webpack-plugin does not work with webpack 4. Use mini-css-extract-plugin instead.
webpack 4 : the webpack dev server
Running npm run devwhenever you make changes to your code? Far from ideal.
It takes just a minute to configure a development server with webpack.
Once configured webpack dev server will launch your application inside a browser.
It will automagically refresh the browser’s window as well, every time you change a file.
To set up webpack dev server install the package with:
- npm i webpack-dev-server --save-dev
Next up open package.jsonand adjust the scripts like the following:
- "scripts": {
- "start": "webpack-dev-server --mode development --open",
- "build": "webpack --mode production"
- }
Save and close the file.
Now, by running:
- npm run start
you’ll see webpack dev server launching your application inside the browser.
webpack dev server is great for development. (And it makes React Dev Tools work properly in your browser).
Stay tuned! More coming soon…
Webpack 4 Tutorial: from 0 Conf to Production Mode的更多相关文章
- webpack 4 :从0配置到项目搭建
webpack4发布以来,我写项目都是用脚手架,即使再简单的项目,真的是really shame..虽然道听途说了很多 webpack4 的特性,却没有尝试过,因为它给人的感觉就是,em...很难.但 ...
- nginx: [emerg] unknown directive "聽" in D:\software03\GitSpace\cms\nginx-1.14.0/conf/nginx.conf:36
nginx: [emerg] unknown directive "聽" in D:\software03\GitSpace\cms\nginx-1.14.0/conf/nginx ...
- webpack前端构建angular1.0!!!
webpack前端构建angular1.0 Webpack最近很热,用webapcak构建react,vue,angular2.0的文章很多,但是webpack构建angualr1.0的文章找来找去也 ...
- unknown directive "" in E:\canteen\nginx-1.16.0/conf/nginx.conf:3-------文本编辑器修改nginx配置文件的坑
nignx小白一个,今天在配置nginx的时候,理所当然的用了文本编辑器编辑并保存了一下nginx的nginx.conf配置文件,一不小心就折腾了几个钟. 保存之后就nginx -s reload一下 ...
- Caused by: org.xml.sax.SAXParseException; systemId: file:/home/hadoop/hive-0.12.0/conf/hive-site.xml; lineNumber: 5; columnNumber: 2; The markup in the document following the root element must be well
1:Hive安装的过程(Hive启动的时候报的错误),贴一下错误,和为什么错,以及解决方法: [root@master bin]# ./hive // :: INFO Configuration.de ...
- Windows环境下执行hadoop命令出现Error: JAVA_HOME is incorrectly set Please update D:\SoftWare\hadoop-2.6.0\conf\hadoop-env.cmd错误的解决办法(图文详解)
不多说,直接上干货! 导读 win下安装hadoop 大家,别小看win下的安装大数据组件和使用 玩过dubbo和disconf的朋友们,都知道,在win下安装zookeeper是经常的事 ...
- 从0开始搭建vue+webpack脚手架(四)
之前1-3部分是webpack最基本的配置, 接下来会把项目结构和配置文件重新设计,可以扩充更多的功能模块. 一.重构webpack的配置项 1. 新建目录build,存放webpack不同的配置文件 ...
- webpack@3.6.0(1) -- 快速开始
本篇内容 前言 配置入口和输出 热更新 loader配置 js代码压缩 html的打包与发布 前言 //全局安装 npm install -g webpack(3.6.0) npm init //安装 ...
- webpack入门级 - 从0开始搭建单页项目配置
前言 webpack 作为前端最知名的打包工具,能够把散落的模块打包成一个完整的应用,大多数的知名框架 cli 都是基于 webpack 来编写.这些 cli 为使用者预设好各种处理配置,使用多了就会 ...
随机推荐
- scrapy spider官方文档
Spiders Spider类定义了如何爬取某个(或某些)网站.包括了爬取的动作(例如:是否跟进链接)以及如何从网页的内容中提取结构化数据(爬取item). 换句话说,Spider就是您定义爬取的动作 ...
- 00-翻译IdentityServer4的目的
强迫自己阅读英文文档 加深IdentityServer4的概念认识
- SQL Server 查询性能优化——创建索引原则(二)
三:索引的建立原则 一般来说,建立索引要看数据使用的场景,换句话来说哪些访问数据的SQL语句是常用的,而这些语句是否因为缺少索引(也有可能是索引过多)变的效率低下.但绝不是所有的SQL语句都要建立索引 ...
- Bootstrap File Input 中文文档
手动安装 您也可以手动地安装插件到你的项目中.只要下载源ZIP或TAR球和提取资产(CSS和JS插件文件夹)到你的项目中. 使用 步骤1:在你页面头部加载以下类库. <link href=&qu ...
- ueditor图片无法左右对齐的解决
找到ueditor的配置文件ueditor.config.js,里面搜索 whiteList 然后在下面找到img,在里面添加 'style'. 添加后如下: img : [ 'src', 'alt' ...
- AXIOS源代码重点难点分析
摘要 vue使用axios进行http通讯,类似jquery/ajax的作用,类似angular http的作用,axios功能强大,使用方便,是一个优秀的http软件,本文旨在分享axios源代码重 ...
- [HAOI2015]数字串拆分
题目描述 你有一个长度为n的数字串.定义f(S)为将S拆分成若干个1~m的数的和的方案数,比如m=2时,f(4)=5,分别为4=1+1+1+1你可以将这个数字串分割成若干个数字(允许前导0),将他们加 ...
- codefroces 946G Almost Increasing Array
Description给你一个长度为$n$的序列$A$.现在准许你删除任意一个数,删除之后需要修改最小的次数使序列单调递增.问最小次数.$1≤n≤200000$ExamplesInput55 4 3 ...
- Go学习——new()和 make()的区别详解(转载)
这篇文章主要介绍了Go语言中new()和 make()的区别详解,本文讲解了new 的主要特性.make 的主要特性,并对它们的区别做了总结,需要的朋友可以参考下 概述 Go 语言中的 new 和 m ...
- [USACO Jan09] 安全路径
Gremlins最近在农场上泛滥,它们经常会阻止牛们从农庄(牛棚_1)走到别的牛棚(牛_i的目的 地是牛棚_i).每一个gremlin只认识牛_i并且知道牛_i一般走到牛棚_i的最短路经.所以它 们在 ...