The profile
With the continuous development and expansion of the front end, the front end is becoming more and more complex. Componentization, modularization, engineering and automation have become an indispensable part of the development of the front end. Specifically, the problem facing the front end engineering is how to improve the production efficiency in the stage of coding -> testing -> maintenance.
Front-end engineering is the use of software engineering technology and methods to develop, maintain and manage front-end projects.
Front-end engineering tasks
The front-end should not only ensure functionality but also performance, reducing the number of HTTP requests, compression, merging, preprocessing, specification, cleaning, packaging, transformation, etc.
In most cases, the source code does not run directly on the front end and must be converted to run properly. A build does just that, converting source code into executable javascript, CSS, HTML code to be published online, including the following.
- Code conversion: TypeScript to JavaScript, SCSS to CSS, etc.
- File optimization: compress JavaScript, CSS, HTML code, compress and merge images, etc.
- Code segmentation: extract the common code of multiple pages, extract the code that does not need to execute part of the first screen and load it asynchronously;
- Module merge: in a modular project, there will be many modules and files. You need to build functions to merge modules into a single file.
- Automatic refresh: monitor local source code changes, automatically rebuild, refresh the browser;
- Code verification: verify code compliance and pass unit tests before it is submitted to the repository;
- Automatic release: After updating the code, automatically build the online release code and transfer it to the release system.
In fact, construction is the embodiment of engineering and automation ideas in front-end development, a series of processes with code to achieve, so that the code automatically execute this series of complex processes. Builds inject more life into front-end development and free up our productivity.
Front-end engineering tools
History has seen a succession of build tools, each with its own strengths and weaknesses. Because front-end engineers are familiar with JavaScript and Node.js can handle all build requirements, most build tools are developed in Node.js.
The main function of the build tool is to automate processing, such as checking, precompiling, merging, and compressing code; Sprite map generation, sourceMap, version management; Run unit tests, monitor, etc., and of course there are tools that provide modular, componentized development process capabilities.
Tools can be divided into three categories by type:
Task-based tools: Grunt, Gulp
They automatically perform assigned tasks, like an assembly line, putting resources on it and processing them through different plug-ins, they have active communities, rich plug-ins, and they make it easy to create various workflows.
Modular packaging-based tools: Browserify, Webpack, rollup.js
Node.js development experience should be familiar with modules, need to reference components directly a require IS OK, this kind of tool is this mode, can also achieve on demand, asynchronous loading module.
Integrated tools: Yeoman, FIS, JDF, Athena, Cooking, weflow
Scaffolding tools that use multiple technology stacks have the advantage of being out-of-the-box, but the disadvantage is that they constrain technology selection and are relatively expensive to learn.
WebPack
Webpack is a static module bundler for modern JavaScript applications. When WebPack works with an application, it recursively builds a Dependency graph containing every module the application needs, and then packages all of those modules into one or more bundles.
Webpack is a tool to package modular JavaScript. In Webpack, all files are modules, through Loader to convert files, through Plugin to inject hooks, and finally output files composed of multiple modules. Webpack focuses on building modular projects.
The front page of its official website vividly illustrates what Webpack is, as follows:
All files, such as JavaScript, CSS, SCSS, pictures and templates, are modules in Webpack’s eyes. The advantage of this is that the dependency between modules can be clearly described, so that Webpack can combine and package modules easily. After processing by Webpack, the final output will be static resources that the browser can use.
Webpack has a great deal of flexibility to configure how files are handled, which is generally used as follows:
module.exports = {
// Entry of all modules, from which Webpack recursively resolves all dependent modules
entry: './app.js'.output: {
// Package all the modules that the entry depends on into a bundle.js output file
filename: 'bundle.js'}}Copy the code
The characteristics of the Webpack
Think of everything as a module: CSS, JS, Image, HTML can be referenced to each other by defining entry.js, keeping track of all dependent files, processing each module through Loader and plugins, and packaging it together.
On-demand loading: During the packaging process, Webpack divides files into chunks through the Code Splitting function, and can separately extract the repeated parts as commonChunk to realize on-demand loading.
Webpack is especially suitable for building single-page applications with react. js and Vue. Js and large projects requiring multi-party cooperation, which can greatly improve development efficiency and experience when the standard procedures have been agreed.
resources
Liverpoolfc.tv: webpack.js.org/
Github:github.com/webpack/web…
Chinese website: www.webpackjs.com/
Webpack e-book: webpack.wuhaolin. Cn /
The working process
Set up the WebPack development environment
- To install NodeJS, go to nodejs.cn/download/…
2. Install webPack: npm init -y yarn add webpack webpack-cli --dev
Const path=require(‘path’); const path=require(‘path’); const path=require(‘path’);
Module.exports ={// specify the location of the entry file entry:"./ SRC /index.js", // set output: Resolve (__dirname,'dist'), // filename: "bundle.js"}}; Path. resolve Specifies the path to the file. _dirname is the absolute path of the current module.Copy the code
- Use the webpack command to pack.
webpack --config webpack.config.js Copy the code
Core concepts and execution process
In Webpack everything is a module, a module for a file. Webpack recursively finds all dependent modules starting from the configured Entry.
Webpack treats everything as a module, whether CSS, JS, Image, or HTML can be referenced to each other. Node.js has supported modular programming since its inception. There are a variety of tools on the Web that support JavaScript modularity, each with its own strengths and limitations. Webpack builds on the lessons learned from these systems and applies the concept of modules to any file in the project.
Compared to node.js modules, Webpack modules can express their dependencies in a variety of ways. Here are a few examples:
- ES2015 import statement;
- CommonJS require() statement;
- AMD DEFINE and require statements;
- @import statements in CSS /sass/ LESS files;
- Style (url (…). ) or HTML file ( image url.
Supported module type
Webpack can support various languages and preprocessor writing modules through loader. Loader describes how WebPack handles non-javascript modules and introduces these dependencies into bundles. The WebPack community has built Loaders for a variety of popular languages and language processors, including:
- CoffeeScript
- TypeScript
- ESNext (Babel)
- Sass
- Less
- Stylus
2.1 the entrance
Entry, the first step in the build that Webpack performs will start with Entry, which can be abstracted into input.
The entry point indicates which module WebPack should use as a starting point for building its internal dependency diagram. Once at the entry point, WebPack finds out which modules and libraries are (directly and indirectly) dependent on the entry point.
Each dependency is then processed and finally exported to a file called Bundles, which we will discuss in detail in the next section.
You can specify an entry starting point (or multiple entry starting points) by configuring the Entry property in the Webpack configuration. The default value is./ SRC.
Let’s look at the simplest example of an Entry configuration:
//webpack.config.js
module.exports = {
entry: './path/to/my/entry/file.js'
};
Copy the code
The Entry attribute can be configured in a number of ways, depending on the specific requirements of your application.
{
entry: {
app: './src/app.js'.search: './src/search.js'
},
output: {
filename: '[name].js'.path: __dirname + '/dist'}}Copy the code
Common placeholders:
- [hash] : hash of the module identifier;
- [chunkhash] : Hash of chunk content.
- [name] : module name, key name, not file name;
- [id] : Module identifier;
- [query] : query of the module, for example, filename? The following string;
- [contenthash] : Hash of a single file.
2.2 export (output)
Output the result after Webpack has gone through a series of processes to arrive at the desired code. The Output attribute tells WebPack where to export the bundles it creates and how to name these files, with the default being./dist. Basically, the entire application structure is compiled into a folder in the output path you specify. You can configure these processes by specifying an output field in the configuration:
//webpack.config.js
const path = require('path');
module.exports = {
entry: './path/to/my/entry/file.js'.output: {
path: path.resolve(__dirname, 'dist'),
filename: 'my-first-webpack.bundle.js'}};Copy the code
In the example above, we use the output.filename and output.path attributes to tell the name of the Webpack bundle and where we want the bundle to emit. In case you’re wondering what the path module imported at the top of the code is, it’s a Node.js core module that manipulates file paths.
2.3 Configuring the Packaged Mode
We need to provide the mode attribute at packaging time to distinguish between the development environment and the production environment to split the configuration file
├─ Build │ ├─ ├─ ├.dev.js │ ├─ ├─ ├.prod.jsCopy the code
The config parameter specifies which configuration file to use for packaging, and the env parameter distinguishes production and development environments.
Configure packaging commands in package.json:
"scripts": {
"build": "webpack --env.production --config ./build/webpack.base"."dev": "webpack --env.development --config ./build/webpack.base"
}
Copy the code
Merge configuration files
We can determine whether the current environment is a development environment to load different configurations. Here we need to do configuration merge install webpack-merge:
npm install webpack-merge --save-dev
Copy the code
Webpack. Dev configuration
module.exports = {
mode: "development"};Copy the code
Webpack. Prod configuration
module.exports = {
mode: "production"};Copy the code
Webpack. Base configuration
const path = require("path");
const merge = require("webpack-merge");
// Development environment
const dev = require("./webpack.dev");
// Production environment
const prod = require("./webpack.prod");
const base = {
// Basic configuration
entry: "./src/index.js".output: {
filename: "bundle.js".path: path.resolve(__dirname, ".. /dist"),}};module.exports = (env) = > {
if (env.development) {
return merge(base, dev);
} else {
returnmerge(base, prod); }};Copy the code
In future development, we will put the common logic in base, and the configuration of development and production pairs will also be stored separately!
2.4 Module Converter (Loader)
Module converter, used to convert the original content of the module into new content as required.
In essence, WebPack Loader converts all types of files into modules that the application’s dependency diagram (and ultimately its bundle) can reference directly.
At a higher level, loader has two goals in the webpack configuration:
- The test property identifies the files or files that should be converted by the corresponding loader.
- The use attribute indicates which loader should be used for conversion.
//webpack.config.js;
const path = require("path");
module.exports = {
output: {
filename: "my-first-webpack.bundle.js",},module: {
rules: [{ test: /\.txt$/, use: "raw-loader"}],}};Copy the code
In the above configuration, the rules property is defined for a single Module object, which contains two required properties: test and use. This tells the Webpack compiler the following:
“Webpack compiler, when you encounter a” path that is resolved to ‘.txt’ in require()/import statement “, use raw-loader to convert it before you package it.”
2.5 plug-in (plugins)
Extension plugins that inject extension logic at specific points in the Webpack build process to change the build result or do what you want.
Loaders are used to transform certain types of modules, while plug-ins can be used to perform a wider range of tasks. Plug-ins range from packaging optimization and compression to redefining variables in the environment. Plug-in interfaces are extremely powerful and can be used to handle a wide variety of tasks.
To use a plugin, you simply require() it and add it to the plugins array. Most plug-ins can be customized with options. You can also use the same plug-in multiple times for different purposes in a configuration file by using the new operator to create an instance of it.
// webpack.config.js
const HtmlWebpackPlugin = require('html-webpack-plugin'); // Install via NPM
module.exports = {
module: {
rules: [{test: /\.txt$/, use: 'raw-loader'}},plugins: [
new HtmlWebpackPlugin({template: './src/index.html'}})];Copy the code
2.6 mode (mode)
By selecting either Development or Production to set the mode parameter, you can enable the optimization built into WebPack for that mode
module.exports = {
mode: 'production'
};
Copy the code
When you have multiple Webpack files, you can set patterns to production and development files separately.
Webpack4 allows us to specify whether compilation is in development mode or production mode, which is controlled by the mode configuration, and value is an enumerated value: Development/Production, corresponding to development mode and production mode respectively (this configuration can be used as a configuration parameter on the command line or as a configuration item in the configuration file; the default value is production mode).
The source code still doesn’t support debugging (it’s all wrapped in eval). Specifying how source-map is generated at compile time (eval is the default) can solve the problem.
2.7 Code Blocks (Chunk)
A Chunk is composed of multiple modules for code merging and splitting.
2.8 WebPack execution process
When Webpack starts, it recursively resolves all modules that Entry depends on, starting from the Module configured in the Entry. When a Module is found, the system finds the corresponding conversion rule based on the configured Loader, converts the Module, and resolves the Module dependent on the current Module. These modules are grouped by Entry, and an Entry and all its dependent modules are assigned to a group called a Chunk. Finally, Webpack converts all chunks into files for output. Webpack executes the logic defined in the Plugin at appropriate times throughout the process.
Module converter Loader
Loader is used to convert the module source code. Loader allows you to preprocess files when importing or “loading” modules. As such, Loader is similar to “tasks” in other build tools and provides a powerful way to handle the front-end build steps. !
Loader is used to convert resource files in application programs. They are functions (running in Node.js) that take the resource file as the source of the argument and return the new resource file.
3.1 use the loader
Loaders are specified in the webpack.config.js file. Module. rules allows you to specify multiple loaders in the webpack configuration. The default loader is executed from bottom to top and from right to left, but the execution order can be manually defined. This is a concise way to show the Loader and helps keep the code simple. It also gives you a global overview of each loader:
module: {
rules: [{test: /\.css$/,
use: [
{ loader: "style-loader" },
{
loader: "css-loader".options: {
modules: true,},},],},]; }Copy the code
Loaders needs to be installed separately and configured under the modules keyword in webpack.config.js. Loaders configuration includes the following aspects:
Test: a regular expression that matches the extended name of the file processed by loaders (mandatory) Loader: The name of the loader (mandatory) include/exclude: Manually add files (folders) that must be processed or exclude files (folders) that do not need to be processed (optional) Query: Additional setup options for Loaders (optional)Copy the code
3.2 Common Loaders
3.2.1 file
- Raw -loader Load file raw content (UTF-8)
- Val-loader executes the code as a module and exports to JS code
- Url-loader works like a file loader, but returns a data URL if the file is smaller than the limit
- File-loader sends the file to the output folder and returns the (relative) URL
3.2.2 JSON
- Json-loader loads JSON files (default included)
- Json5-loader loads and translates JSON 5 files
- Cson -loader loads and translates Cson files
3.2.3 Transpiling
- Script-loader executes a JavaScript file (such as in a script tag) once in a global context, without parsing
- Babel-loader loads the ES2015+ code and then translates it to ES5 using Babel
- Buble-loader uses buble to load ES2015+ code and translate the code to ES5
- Traceur – Loader loads the ES2015+ code and then translates it into ES5 using traceur
- Ts-loader or awesome-typescript-loader loads typescript 2.0+ like JavaScript
- Coffee-loader loads CoffeeScript like JavaScript
3.2.4 template (Templating)
- Html-loader exports HTML as a string and references static resources
- Pug-loader loads the PUg template and returns a function
- Jade-loader loads the Jade template and returns a function
- Markdown-loader translates markdown to HTML
- React-markdown-loader compiles markdown into the -react component using markdown-parse parser
- Posthtml -loader uses PosthTML to load and convert HTML files
- Handlebars -loader transfers handlebars to HTML
- Markup -inline-loader converts an inline SVG/MathML file to HTML. Useful when applying icon fonts, or CSS animations to SVG.
3.2.5 style
- Style-loader adds the module’s export to the DOM as a style
- Css-loader parses the CSS file, loads it using import, and returns the CSS code
- Less-loader loads and translates less files
- Sass -loader loads and translates SASS/SCSS files
- Postcss-loader Loads and translates CSS/SSS files using postCSS
- Stylus – Loader loads and translates stylus files
3.2.6 Linting && Testing
- Mocha – Loader using Mocha tests (browser /NodeJS)
- Eslint-loader PreLoader, which uses esLint to clean code
- Jshint-loader PreLoader: uses jshint to clear codes
- Jscs-loader PreLoader: uses JSCS to check code styles
- Coverjs-loader PreLoader, which uses CoverJS to determine test coverage
3.3 Raw-loader (Raw Content Converter)
A loader that can be used to load files as strings, using UTF-8 encoding. The installation
yarn add raw-loader --dev
Copy the code
module: {
rules: [{test: /\.txt$/,
use: "raw-loader",},]; }Copy the code
3.4 Handling CSS Files
3.4.1 Parsing CSS Styles
We are introducing CSS styles in our JS files!
import "./index.css";
Copy the code
When packaging is performed again, the CSS cannot be parsed
ERROR in ./src/index.css 1:4
Module parse failed: Unexpected token (1:4)
You may need an appropriate loader to handle this file type, currently no loaders are configured to process this file. See https://webpack.js.org/concepts#loaders
Copy the code
Install the loader
yarn add style-loader css-loader --save-dev
Copy the code
module: {
rules: [{test: /\.css$/,
use: ["style-loader"."css-loader"],},]; }Copy the code
3.4.2 Extract the style file
By default, style extraction is only done at packaging time
module.exports = (env) = > {
let isDev = env.development;
const base = {
/*source... * /
};
if (isDev) {
return merge(base, dev);
} else {
returnmerge(base, prod); }};Copy the code
Install the pull-out plug-in
npm install mini-css-extract-plugin --dev
Copy the code
Configure the extraction plug-in
{
test: /\.css$/,
use: [
!isDev && MiniCssExtractPlugin.loader,
isDev && 'style-loader'."css-loader"
].filter(Boolean)}! isDev &&new MiniCssExtractPlugin({
filename: "css/[name].css"
})
Copy the code
The final file configuration is posted below:
const path = require("path");
const dev = require("./webpack.dev");
const prod = require("./webpack.prod");
const merge = require("webpack-merge");
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
const HtmlWebpackPlugin = require("html-webpack-plugin");
module.exports = (env) = > {
let isDev = env.development;
const base = {
entry: "./src/index.js".output: {
filename: "[name].js".path: path.resolve(__dirname, ".. /dist"),},module: {
rules: [{test: /\.css$/,
use: [
!isDev && MiniCssExtractPlugin.loader,
isDev && "style-loader"."css-loader",
].filter(Boolean),},],},plugins: [
!isDev &&
new MiniCssExtractPlugin({
filename: "css/[name].css",}).new HtmlWebpackPlugin({
filename: "index.html".template: path.resolve(__dirname, ".. /public/template.html"),
hash: true.minify: {
removeAttributeQuotes: true,
},
}),
].filter(Boolean),};if (isDev) {
return merge(base, dev);
} else {
returnmerge(base, prod); }};Copy the code
3.4.3 CSS preprocessor
Different CSS preprocessors need to install different Loaders for parsing
- sass: sass-loader node-sass
- less: less-loader less
- stylus: stylus-loader stylus
Using sass
{
test:/\.scss$/,
use:[
!isDev && MiniCssExtractPlugin.loader,
isDev && 'style-loader'."css-loader"."sass-loader"
].filter(Boolean)}Copy the code
A CSS file may be referenced using the @import syntax in the CSS file, and SCSS may also be imported into the referenced CSS file
{
test: /\.css$/,
use: [
!isDev && MiniCssExtractPlugin.loader,
isDev && 'style-loader',
{
loader:"css-loader".options: {importLoaders:1 // The imported files need to be processed by calling sass-loader}},"sass-loader"
].filter(Boolean)},Copy the code
3.4.4 Handling style prefixes
Add style prefixes using postCSs-loader
npm install postcss-loader autoprefixer
Copy the code
Add prefixes before working with CSS
{
test: /\.css$/,
use: [
!isDev && MiniCssExtractPlugin.loader,
isDev && 'style-loader',
{
loader:"postcss-loader".options: {plugins: [require('autoprefixer')]}},"postcss-loader"."sass-loader"
].filter(Boolean)},Copy the code
Alternatively, you can create the postCSS configuration file postcss.config.js
module.exports = {
plugins: [require("autoprefixer")]};Copy the code
You can configure the browser compatibility range. Browserslistrc
Cover 99.5%Copy the code
3.4.5 CSS compression
In production we need to compress the CSS file, configure the Minimizer option, and install the compression plugin
npm i optimize-css-assets-webpack-plugin terser-webpack-plugin --save-dev
Copy the code
Configure compression in the webpack.prod.js file
const OptimizeCSSAssetsPlugin = require("optimize-css-assets-webpack-plugin");
const TerserJSPlugin = require("terser-webpack-plugin");
optimization: {
minimizer: [new TerserJSPlugin({}), new OptimizeCSSAssetsPlugin({})];
}
Copy the code
3.4.6 File Fingerprint
- Hash Hash value of the entire project
- Chunkhash generates a hash value based on the entry
- ContentHash Hash value generated based on the contents of each file
We can reasonably use hash stamps to cache files
! isDev &&new MiniCssExtractPlugin({
filename: "css/[name].[contentHash].css"});Copy the code
3.5 Handling file types
3.5.1 Processing referenced images
import logo from "./webpack.png";
let img = document.createElement("img");
img.src = logo;
document.body.appendChild(img);
Copy the code
Using file-loader, the image is packed and the packed path is returned
{
test:/\.jpe?g|png|gif/,
use:{
loader:'file-loader'.options: {name:`img/[name].[ext]`}}}Copy the code
3.5.2 processing icon
Binary files are also packaged using file-loader
{
test:/woff|ttf|eot|svg|otf/,
use:{
loader:'file-loader'}}Copy the code
3.5.3 Converting to Base64
The url-loader is used to convert the images that meet the requirements into base64. If the url-loader does not meet the requirements, the url-loader automatically invokes file-loader to process the images
{
test:/\.jpe?g|png|gif/,
use:{
loader:'url-loader'.options: {limit:100*1024.name:`img/[name].[ext]`}}}Copy the code
3.6 Processing JS Modules
3.6.1 track willes6
Code compiled intoes5
code
The translation of the code is left to Babel
yarn add @babel/core @babel/preset-env babel-loader --dev
Copy the code
@babel/core is the core module in Babel, and @babel/preset-env is the set of ES6 to transform ES5 plug-ins. Babel-loader is the bridge between WebPack and Loader.
const sum = (a, b) = > {
return a + b;
};
Copy the code
Add Babel configuration file.babelrc
{
"presets": [["@babel/preset-env"]]}Copy the code
Configure the loader
module: {
rules: [{ test: /\.js$/, use: "babel-loader"}},Copy the code
Packaging now successfully converts ES6 syntax to ES5 syntax!
3.6.2 Parsing decorators
yarn add @babel/plugin-proposal-class-properties @babel/plugin-proposal-decorators --dev
Copy the code
"plugins": [["@babel/plugin-proposal-decorators", { "legacy": true }],
["@babel/plugin-proposal-class-properties", {"loose":true}]]Copy the code
Legacy: True indicates that the decorator decorator is continued. When loose is false, object.defineProperty is used to define properties
- Plugin will run ahead of Preset
- Plugin will run sequentially starting from the first, Preset is reversed
3.6.3 polyfill
According to the.browserslistrc file, convert to the browser API used
"presets": [["@babel/preset-env", {"useBuiltIns":"usage".// Load as needed
"corejs":2 // Corejs replaces pollyfill}]]Copy the code
Install corejs
yarn add core-js@2
Copy the code
Use the transform-Runtime A plugin that enables the re-use of Babel’s injected helper code to save on Codesize. It helps us save code
yarn add @babel/plugin-transform-runtime @babel/runtime --dev
Copy the code
Configure the plug-in in.babelrc
"plugins": [
"@babel/plugin-transform-runtime"
]
Copy the code
Add eslint 3.6.4 radar echoes captured
Install eslint
npm install eslint
npx eslint --init Initialize the configuration file
Copy the code
{
test:/\.js/,
enforce:'pre',
use:'eslint-loader'
},
Copy the code
Eslint-loader can be configured to verify the correctness of JS files in real time. Pre indicates that it is executed before all loaders are executed
3.7 Configuring the TS Environment
3.7.1 use ts – loader
To use the TS, you need to install the TS-related configuration
npm install typescript ts-loader --save-dev
Copy the code
Generate the TS configuration file
npx tsc --init
Copy the code
Configuration ts – loader
{
test:/\.tsx? /,
use: ['ts-loader'].exclude: /node_modules/
}
Copy the code
Change the import file to ts file
let a: string = "hello";
console.log(a);
Copy the code
NPM run dev: Ts file parsed properly.
3.7.2 use preset – typescript
You don’t need typescript
npm install @babel/preset-typescript
Copy the code
{
"presets": [["@babel/preset-env",
{
"useBuiltIns": "usage"."corejs": 2}]."@babel/preset-react"["@babel/preset-typescript",
{
"allExtensions": true}]],"plugins": [["@babel/plugin-proposal-decorators", { "legacy": true }],
["@babel/plugin-proposal-class-properties", { "loose": true}]."@babel/plugin-transform-runtime"]}Copy the code
Plugins plugins
4.1 Plug-in Overview
Plugin is designed to extend Webpack functionality by injecting hook implementations into the build process, which gives Webpack a lot of flexibility.
Plug-ins are the backbone of WebPack. Webpack itself is also built on top of the same plugin system you use in your WebPack configuration! Plug-ins are designed to solve other things that loader cannot implement.
4.2 HTML Webpack Plugin (create HTML plug-in)
This plug-in is used to automatically generate HTML pages, can generate a single page or multiple pages, and before generating it can be given some configuration parameters, it will be generated according to the way you want to generate pages.
The installation
yarn add html-webpack-plugin --dev
Copy the code
Introduce modules in webpack.config.js
const HtmlWebpackPlugin=require('html-webpack-plugin');
Copy the code
New an instance in the plugins object in webpack.config.js
new HtmlWebpackPlugin({ template: "./src/templates/tmpl03.html", templateParameters: { title: "Hello App", content: "123456", key: "value",}, minify: {removeComments: true,Copy the code
Parameters:
- Title: Generates the titile element of the page;
- Filename: specifies the name of the generated HTML file. Default index.html, can be configured directly with subdirectories;
- Template: specifies the template file path.
- Injectscript The location of inject, with four optional values:
- True: The default, script tag at the bottom of the body of the HTML file;
- Body: with true;
- Head: The script tag is inside the HEAD tag of an HTML file;
- False: Do not insert the generated JS file, only the generated HTML file.
- Minify: Compress HTML files. Property value is false or compression option value. Default false does not compress HTML files.
- Hash: Adds a hash value to the end of the generated JS file. This hash value is the hash value for this Webpack compilation. The default false;
- Chunks: Which JS files to reference in the HTML file for use in multi-entry files. When chunks are not specified, all files are referenced.
4.3 Mini-CSS-extract-Plugin (Extract CSS plug-in separately)
A plug-in that extracts CSS as a separate file, creates a CSS file for every JS file that contains CSS, and supports on-demand loading of CSS and sourceMap.
By default CSS is a style injected by JS, like this:
Installation:
yarn add mini-css-extract-plugin --dev
Copy the code
use
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
module.exports = {
plugins: [
new MiniCssExtractPlugin({
// The configuration like webpackOptions.output can be ignored
filename: "[name].css".chunkFilename: "[id].css",})],module: {
rules: [{test: /\.css$/,
use: [
{
MiniCssExtractPlugin.loader,
options: {
// You can specify a publicPath here
// publicPath in webPackoptions. output is used by default
publicPath: ".. /",}},"css-loader",],},],},};Copy the code
This plug-in should only be used in production configurations, and style-loader should not be used in the loaders chain, especially in development, since HMR is not currently supported by this plug-in
4.4 clean-webpack-plugin (Delete or clean up the build directory)
When using HtmlWebpackPlugin, you need to delete the dist directory and look at the generated file. The clean-webpack-plugin can do this
When using HtmlWebpackPlugin, you need to delete the dist directory and look at the generated file. The clean-webpack-plugin can do this
The installation
yarn add clean-webpack-plugin --dev
Copy the code
Introduce modules in webpack.config.js
const { CleanWebpackPlugin } = require("clean-webpack-plugin");
Copy the code
Create a cleanup object at the beginning of your plugins
Plugins :[new CleanWebpackPlugin(['./dist']), // This should be on top of the plugins:[new CleanWebpackPlugin(['./dist']), // This should be on top of the plugins:[new CleanWebpackPlugin(['.Copy the code
4.4.1 cleanOnceBeforeBuildPatterns
This parameter configures which files to delete before build, and do not delete which files, do not delete the file before a logical operator! The * sign can be handled by the station character, what does it start with, what does it end with
new CleanWebpackPlugin({
cleanOnceBeforeBuildPatterns: ['main*.*', '!vendor', '!vendor.manifest.json']
}),
Copy the code
4.4.2 cleanAfterEveryBuildPatterns
This parameter indicates which files to delete after the build, and which files to not delete, do not delete the file before a logical operator! The * sign can be handled by the station character, what does it start with, what does it end with
new CleanWebpackPlugin({
cleanAfterEveryBuildPatterns: ['static*.*', '!static1.js'],
}),
Copy the code
About the clean – webpack – all plugins plugin configuration parameter refer to: www.npmjs.com/package/cle… .
DevServer Development server
Webpack-dev-server is a simple server based on Node.js and WebPack. It uses Webpack-dev-Middleware to package webpack builds on the server side. A runtime is injected into the client to receive server-side build package information.
5.1 Quickly Starting DevServer
After the installation is successful, run the webpack-dev-server command in the root directory of the project, and the DevServer will start. You will see a string of log output from the console:
Project is running at http://localhost:8080/
webpack output is served from /
Copy the code
This means that DevServer starts the HTTP server listener at http://localhost:8080/, and DevServer stays in the background while it is running. Visit this url to get the index.html in the project root directory.
Note: Instead of using the webpack command to generate a dist directory, enter the address http://localhost:8080/ in the browser and the page will display normally. The reason for this is that devServer saves webPack-built files in memory so that you can preview them without packing them
5.2 Parameter Settings
In webpack.config.js you can configure dev-server as needed to meet more of your needs.
// webpack.config.js to configure devServer
devServer: {
clientLogLevel: 'warning'.historyApiFallback: true.hot: true.compress: true.host: 'localhost'.port: 8080
}
Copy the code
- Hot: Updates the Hot module. That is, after modification or module, the save will be automatically updated, the page does not need to refresh to present the latest effect.
. This is not and webpack HotModuleReplacementPlugin (HMR) function of the plugin is not same? Yes, but note that HMR is the plugin that actually implements hot module updates. With Hot: True configured in devServer, WebPack automatically adds the HMR plugin. So module hot update is ultimately the role of the plug-in HMR;
- Host: write the host name. The default localhos;
- Port: indicates the port number. The default 8080;
- Compress: If true, compress your code when the virtual server is started. Accelerating development processes and optimizations;
- ContentBase: Where you want to provide content to the virtual server. It’s better to put absolute paths here. By default, it will use your current working directory to serve the content;
- PublicPath: If publicPath is configured, url = ‘host name’ + ‘publicPath ‘+
‘Old url.path’. This is the same as output.publicPath;
- Proxy: Proxies these urls when you have a separate API back-end development server and want to send API requests on the same domain. It makes sense to look at examples.
proxy: { '/proxy': { target: 'http://your_api_server.com'.changeOrigin: true.pathRewrite: { '^/proxy': ' '}}Copy the code
- Suppose your host name is localhost:8080 and the URL for the request API is http://your_api_ server.com/user/list;
- ‘/ proxy: if you click a button, trigger event request API, then the request url is http://localhost:8080/proxy/user/list;
- ChangeOrigin: if true, then the http://localhost:8080/proxy/user/list to http://your_api_server.com/proxy/user/list. But it’s not the URL we want;
- PathRewrite: rewrites the path. Match /proxy and change to “, so the URL ends up at http://your_api_ server.com/user/list.