webpack入门学习笔记10 —— 在项目中使用图片资源

424 阅读2分钟

1. 写在前面

在前端项目中,图片是必不可少的一种资源。在使用图片的时候,我们可以有以下几种方式:

  • .html 文件中,通过 <img src="" alt=""> 标签引入图片
  • .css 文件中,通过 background: url() 属性来引入图片
  • .js 文件中,通过 import 或者 require 语法来引入图片

但是在基于webpack的项目中,如果你只是简单的引入,而没有对这些图片文件做一些配置处理的话,是不能成功的。比如,如果你在一个 .js 文件中书写以下代码:

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

或者在 .css 文件中,书写以下代码:

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

那么在进行打包编译项目或者启动本地开发服务器的时候,会报出以下错误:

错误提示很明显:我们需要一个合适的loader来处理这些图片文件。

那么在这篇博客中,我们就来讲述一下:如何进行配置webpack,使得图片资源可以在项目中被正常地使用。主要内容包括:

  • 使用 file-loader 处理图片资源
  • 使用 html-withimg-loader 处理图片资源

2. 使用 file-loader 处理图片资源

首先讲述如何使用 file-loader 来处理图片资源,既然是一个loader,那么第一步肯定是安装,安装命令如下:

yarn add file-loader -D

安装完成之后,到 webpack.config.js 文件中进行配置,配置规则非常简单,这里直接给出代码:

module.exports = {
    /* 节省篇幅,其他配置信息已省略 */
    module: {
        rules: [
            {
                test: /\.(png|jpg|jpeg|gif)$/,  // 使用正则匹配文件图片
                use: {
                    loader: 'file-loader'   	// 使用file-loader对这些文件进行处理
                }
            }
        ]
    }
}

这里将其他的配置规则省略了,如果你想看其他的配置规则,可以查看我的 GitHub仓库 - webpack-learning ,或者通过本文末尾的链接,跳转到我之前的博客中进行查看。

这里介绍一下 file-loader 的作用:对项目中使用到的图片文件进行处理,将处理后的文件保存到 输出文件夹

,并返回输出文件夹下该文件的 URL 。如此一来,这个文件就可以被正常使用。

下面我们在项目中体验一下这个loader的作用,在一个 .js 文件中书写以下代码,使用图片资源:

import logo from './logo.png'   // 引入图片
console.log(logo);  

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

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

打包编译之后,就可以在页面上看到这样图片了。

同理,在 .css 文件中也可以正常使用图片资源,参考代码如下:

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

如果这时候,你在 .html 文件中 <img src="" alt=""> 标签引入图片,webpack一样会报错。仅靠file-loader做不到这一点,为了解决这个问题,我们需要 在file-loader的基础上,使用下面讲到的loader。

3. 使用 html-withimg-loader 处理图片资源

这个loader的作用是:处理 .html 文件中引用的图片,使得图片能够被正常使用。但是要注意,使用这个loader的时候,同时也要使用上面的 file-loader

和上面一样,首先我们要做的还是进行安装,安装命令如下:

yarn add html-withimg-loader -D

安装完成之后,到 webpack.config.js 文件中进行配置,配置规则非常简单,这里直接给出代码:

module.exports = {
 	/* 节省篇幅,其他配置信息已省略 */
    module: {
        rules: [
            // 配置 file-loader
            {
                test: /\.(png|jpg|jpeg|gif)$/,   
                use: {
                    loader: 'file-loader'    
                }
            },
            // 配置 html-withimg-loader
            {
                test: /\.html$/,
                use: 'html-withimg-loader'
            }
        ]
    }
}

配置完成之后,我们就可以在 .html 文件中正常使用图片,比如以下代码:

<!DOCTYPE html>
<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>
	<!-- 引入logo.png图片 -->
    <img src="./logo.png" alt="">		
    
</body>
</html>

现在进行打包编译项目,得到编译后的 index.html 文件代码如下:

<!DOCTYPE html>
<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>
    <!-- 注意这里的图片引用路径不再是logo.png -->
    <!-- 这个路径是 file-loader 对文件处理后生成新文件的路径 -->
    <img src=2b9a35ac93ae4d5ea1eb21230d61c324.png alt="">
</body>

</html>

这个时候在浏览器中打开编译后的 index.html 文件,就可以看到我们的图片了。

4. 优化图片处理方式,减少http请求

在编写前端项目的过程中,我们可能会用到很多图片资源,有些图片非常小,只有几KB。但是这些小图片的数量有时却非常大,有的项目中可能有几十个甚至是上百个图片。

这就会导致一个问题:项目上线之后,为了请求这些图片资源,浏览器端会大量使用http请求来获取图片,这就可能导致浏览器的开销过大,性能较低。那么怎么来解决这个问题呢?

这里我们介绍一种编码方式——Base64编码。这不是一种加密解密方式,它是一种编码方式。简单来说,它的作用就是:使用字符来表示任意二进制文件(这些字符包括:A B ... Z a b ... z 0 1 ... 9 + / 等64个字符)。

为了更加贴切的体会Base64编码,你可以复制以下长长的Base64编码,粘贴到浏览器地址栏,便可以看到这段Base64编码表示的图片了。



使用Base64对图片进行编码,就可以将这些图片切入到静态的 .html 文件中,这样就不需要再使用http请求来获取图片了,从而节省浏览器开销,提高性能。

为了在基于Webpack的项目中使用Base64编码处理图片,我们需要使用 url-loader 来进行处理。首先安装该loader,安装命令如下:

yarn add url-loader -D

安装完成之后,我们到 webpack.config.js 文件中进行相关配置,配置非常简单,代码如下:

module.exports = {
   /* 节省篇幅,其他的配置信息已省略 */
    module: {
        rules: [
            {
                test: /\.(png|jpg|jpeg|gif)$/,
                use: {
                    loader: 'url-loader',
                    options: {
                        limit: 200*1024		// 小于200k的图片,使用Base64进行处理
                    }
                }
            }
        ]
    }
}

这里将其他的配置规则省略了,如果你想看其他的配置规则,可以查看我的 GitHub仓库 - webpack-learning ,或者通过本文末尾的链接,跳转到我之前的博客中进行查看。

上述配置非常好理解:对于png、jpg等图片格式的资源,使用url-loader进行处理,如果图片小于200k,那么就是用Base64进行编码;如果图片大于200k,就不做处理,使用http请求来获取图片。

配置完成之后,当我们编译项目时,就会在生成的 .html 文件中看到使用Base64编码后的图片,由于内容较多,就不贴代码,想查看的编译后代码的同学,可以点击 Github连接 进行查看。

5. 写在最后

这是本篇博客的全部内容,关于 file-loader 的更多知识,推荐大家访问 webpack官网 - file-loader

上一篇: webpack入门学习笔记09 —— 在项目中引入全局变量

下一篇: webpack入门学习笔记11 —— 在项目中对打包编译的文件进行分类