Webpack4系列教程(五) 图片相关配置

写在前面

在这篇博客中,我将会你介绍图片处理部分的相关配置

基础配置

CSS中引入图片需要使用file-loader

首先我们把一些图片放在src/assets/imgs目录下,并且引入这些图片
在这里插入图片描述
然后我们配置一条rule:图片文件交给file-loader处理

{ 
    loader: 'file-loader',
    options: {
        outputPath: 'assets/imgs',
        useRelativePath: true
    } 
}

执行打包后dist目录结构如下
在这里插入图片描述

Base64 编码

当图片很小的时候我们可以将图片转换为base64嵌入到css文件中,以减少http请求次数
在处理图片和进行base64编码的时候,需要使用url-loader
我们配置一条rule:图片文件交给url-loader处理

{ 
    loader: 'file-loader',
    options: {
        outputPath: 'assets/imgs',
        useRelativePath: true
    } 
}

执行打包后dist目录结构如下
在这里插入图片描述
图片文件全部被打包到了css文件中
在这里插入图片描述
css文件达到了142kb,这显然不是我们想要的,我们希望体积小的图片转换为base64,体积更大的还是以图片格式保存
我们修改下rule

{ 
    loader: 'url-loader',
    options: {
        outputPath: 'assets/imgs',
        useRelativePath: true,
        limit: 20000 //当图片小于20kb时会转换成base64
    } 
}

执行打包后dist目录结构如下,一张图片被转换成base64,三张以图片格式输出
在这里插入图片描述

压缩图片

使用image-webpack-loader进行图片的压缩
配置如下

{
    test: /\.jpg$/,
    use: [
        { 
            loader: 'url-loader',
            options: {
                name: '[name].min.[ext]'
                outputPath: 'assets/imgs',
                useRelativePath: true,
                limit: 5000 //当压缩后的图片小于5kb时会转换成base64
            } 
        },
        {
            loader: 'image-webpack-loader',
            options: {
                optimizationLevel: 7,
                interlaced: false
              }
        } 
    ]
}

执行打包后dist目录结构如下,两张图片被转换成base64,两张以图片格式输出
在这里插入图片描述

雪碧图

使用postcss-sprites进行图片的压缩
将项目中需要用到的icon合并到一张图以减少图片资源的请求次数
修改postcss.config.js文件,配置如下

module.exports = {
    plugins: [
        require('postcss-sprites')({
            spritePath: 'dist/assets/imgs/sprites'
        }),
        require('autoprefixer')({
            "browsers": [
                "defaults",
                "not ie < 11",
                "last 2 versions",
                "> 1%",
                "iOS 7",
                "last 3 iOS versions"
            ]
        })
    ]
};

在这里插入图片描述
其中sprite.min.png是压缩后的雪碧图

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值