《十五》对打包后的 CSS 文件中的代码进行压缩

CSS 压缩通常是去除无用的空行空格等,因为很难去修改选择器、属性名、属性值等。

在 Webpack 中可以使用 CssMinimizerWebpackPlugin 插件来实现对 CSS 代码的压缩。

CssMinimizerWebpackPlugin 插件只会对打包后的 CSS 文件中的 CSS 代码进行压缩,不会对打包后的 HTML 文件、JS 文件中的 CSS 代码进行压缩。

CssMinimizerWebpackPlugin 插件是使用 cssnano 工具来压缩 CSS 的。
cssnano 工具可以单独使用。

  1. 新建 src/index.css 文件和 src/index.js 文件,并编写代码。
    // src/index.css
    .container {
      width: 100%;
      height: 100%;
      background: none;
    }
    
    .text {
      color: red;
      font-size: 24px;
    }
    
    // src/index.js
    import './index.css'
    
  2. npm install css-loader mini-css-extract-plugin --save-dev 安装 css-loader 和 MiniCssExtractPlugin 插件,并在 webpack.config.js 配置文件中进行配置来处理 CSS。
    const MiniCssExtractPlugin = require('mini-css-extract-plugin')
    
    module.exports = {
      module: {
        rules: [
          // 对 CSS 代码进行转换
          {
            test: /\.css$/,
            use: [MiniCssExtractPlugin.loader, "css-loader"],
          }
        ]
      },
      plugins: [
        // 使用 MiniCssExtractPlugin 将 css 文件抽取为单独的文件
        new MiniCssExtractPlugin({
          filename: 'css/[name].css',
        })
      ]
    }
    
  3. 运行 webpack 命令进行打包,会发现,CSS 文件被抽取为了一个单独的文件,但此时还没有进行任何压缩和丑化。
    请添加图片描述
  4. 安装 CssMinimizerWebpackPlugin 插件:npm install css-minimizer-webpack-plugin --save-dev
  5. webpack.config.js 配置文件中进行配置。
    const MiniCssExtractPlugin = require('mini-css-extract-plugin')
    // 引入 CssMinimizerWebpackPlugin
    const CssMinimizerWebpackPlugin = require('css-minimizer-webpack-plugin')
    
    module.exports = {
      module: {
        rules: [
          {
            test: /\.css$/,
            use: [MiniCssExtractPlugin.loader, "css-loader"],
          }
        ]
      },
      plugins: [
        new MiniCssExtractPlugin({
          filename: 'css/[name].css',
        }),
        // 使用 CssMinimizerWebpackPlugin
        new CssMinimizerWebpackPlugin()
      ]
    }
    
  6. 运行 webpack 命令进行打包,会发现,CSS 代码被压缩了。
    请添加图片描述
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值