1. Write at the front

Images are an essential resource in a front-end project. We can use pictures in the following ways:

  • In the.html file, import the image with the tag
  • In the.css file, the image is introduced through the background: URL () property
  • In the.js file, use the import or require syntax to import images

But in a WebPack-based project, if you simply import the image files without doing some configuration, it won’t work. For example, if you write the following code in a.js file:

import logo from './logo.png'
console.log(logo);
Copy the code

Or in the.css file, write the following code:

body {
    background-color: gray;
    background: url('./logo.png')}Copy the code

The following error is reported when the project is packaged and compiled or the local development server is started:

The error message is obvious: we need a proper loader to process these image files.

In this blog post, we will show you how to configure WebPack so that image resources can be used properly in your project. The main contents include:

  • Use file-loader to process image resources
  • Use htML-withimg-loader to process image resources

2. Use file-loader to process image resources

How to use file-loader to process image resources?

yarn add file-loader -D
Copy the code

After installation, go to the webpack.config.js file to configure, the configuration rules are very simple, here directly give the code:

module.exports = {
    /* To save space, other configuration information is omitted */
    module: {
        rules: [{test: /\.(png|jpg|jpeg|gif)$/.// Use the re to match the file image
                use: {
                    loader: 'file-loader'   	// Use file-loader to process these files}}]}}Copy the code

The rest of the configuration rules are omitted here, but if you want to see other configuration rules, check out my GitHub repository – webpack-Learning, or jump to my previous blog at the end of this article.

File-loader processes the image files used in the project and saves the processed files to the output folder

And returns the URL of the file in the output folder. This way, the file can be used normally.

Here’s a taste of what loader can do in a project: write the following code in a.js file, using image resources:

import logo from './logo.png'   // Import images
console.log(logo);  

let img = new Image();
img.src = logo;

document.getElementsByTagName('body') [0].appendChild(img);
Copy the code

Once packaged and compiled, you should see this image on the page.

In the same way, image resources can be used normally in.css files.

body {
    background-color: gray;
    background: url('./logo.png')}Copy the code

Webpack will also report an error if you import an image with the tag in your.html file. File-loader alone cannot do this. To solve this problem, we need to use the loader described below on the basis of file-loader.

3. Use HTML-withimg-loader to process image resources

This loader is used to process images referenced in.html files so that they can be used normally. Note, however, that using this loader should also use the file-loader above.

As above, the first thing we need to do is to install. The installation command is as follows:

yarn add html-withimg-loader -D
Copy the code

After installation, go to the webpack.config.js file to configure, the configuration rules are very simple, here directly give the code:

module.exports = {
 	/* To save space, other configuration information is omitted */
    module: {
        rules: [
            / / configuration file - loader
            {
                test: /\.(png|jpg|jpeg|gif)$/.use: {
                    loader: 'file-loader'}},/ / configure HTML - withimg - loader
            {
                test: /\.html$/.use: 'html-withimg-loader'}}}]Copy the code

Once configured, we can use images normally in.html files, such as the following code:


      
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="Width = device - width, initial - scale = 1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
<body>
	<! PNG image -->
    <img src="./logo.png" alt="">		
    
</body>
</html>
Copy the code

Now package the compiled project and get the compiled index.html file code as follows:


      
<html lang=en>

<head>
    <meta charset=UTF-8>
    <meta name=viewport content="width=device-width,initial-scale=1">
    <meta http-equiv=X-UA-Compatible content="ie=edge">
    <title>Document</title>
</head>

<body>
    <! -- Notice that the image reference path is no longer logo.png -->
    <! -- this is the path where file-loader generates a new file after processing the file -->
    <img src=2b9a35ac93ae4d5ea1eb21230d61c324.png alt="">
</body>

</html>
Copy the code

At this point, open the compiled index.html file in your browser and you’ll see our image.

4. Optimize image processing to reduce HTTP requests

When writing a front-end project, we may use many image resources, some of which are very small, only a few kilobytes. However, the number of these small images can be very large, and some projects can have dozens or even hundreds of images.

This leads to a problem: after the project goes live, in order to request these image resources, the browser side will use A large number of HTTP requests to obtain images, which may lead to excessive browser overhead and low performance. So how to solve this problem?

Here we introduce a encoding method – Base64 encoding. This is not an encryption or decryption method, it is an encoding method. Simply put, it is used to represent any binary file using characters (such as A, B… Z a b … z 0 1 … 9 + / etc 64 characters).

To get a better feel for the Base64 encoding, you can copy the following long Base64 encoding and paste it into your browser’s address bar to see the image represented by the Base64 encoding.


Copy the code

By using Base64 to encode images, you can cut them into static.html files, eliminating the need for HTTP requests to retrieve images, saving browser overhead and improving performance.

To process images using Base64 encoding in a WebPack-based project, we need to use urL-loader for processing. Install loader. Run the following command to install loader:

yarn add url-loader -D
Copy the code

After the installation, we went to the webpack.config.js file for the relevant configuration, the configuration is very simple, the code is as follows:

module.exports = {
   /* Other configuration information is omitted */ to save space
    module: {
        rules: [{test: /\.(png|jpg|jpeg|gif)$/.use: {
                    loader: 'url-loader'.options: {
                        limit: 200*1024		// For images smaller than 200K, use Base64}}}]}}Copy the code

The rest of the configuration rules are omitted here, but if you want to see other configuration rules, check out my GitHub repository – webpack-Learning, or jump to my previous blog at the end of this article.

The above configuration is very easy to understand: For PNG, JPG and other image format resources, use urL-loader to process, if the image is less than 200K, then use Base64 encoding. If the image is larger than 200K, no processing is done and an HTTP request is used to fetch the image.

After the configuration is completed, when we compile the project, we will see the Base64 encoded image in the generated.html file. Due to the large content, we will not post the code. If you want to view the compiled code, you can click Github link to view it.

5. Write at the end

This is the end of this blog. For more information about file-loader, please visit webpack’s official website – file-loader.

Introduction of global variables into a project

Introduction to WebPack Study Notes 11 – Categorize packaged and compiled files in a project