美文网首页前端自动化工具使用
Webpack4.x 中CSS代码的分离

Webpack4.x 中CSS代码的分离

作者: 小人物的秘密花园 | 来源:发表于2019-08-20 11:26 被阅读1次

    参考

    mini-css-extract-plugin

    目的

    通过webpack打包后的css代码是放js文件中的,这样会使得js文件的体积变大,而分离css代码到单独的css文件中,可以和js并行加载,提高网页加载效率;

    实现

    webacpk4.x中分离css,需要使用mini-css-extract-plugin插件;

    配置

    1.创建本地项目webpack-demo

    mkdir webpack-demo
    cd webpack-demo
    

    2.在webpack-demo的根目录下创建package.json文件

    npm init -y
    
    1. 安装webpack依赖包
    npm i webpack webpack-cli webpack-dev-server --save-dev
    

    模块说明:

    • webpack
      webpack核心

    • webpack-cli
      webpack的脚手架(启动器)

    • webpack-dev-server
      开发环境下用于实时加载依赖

    4.修改package.json文件的scripts属性值,进行打包资源的配置

    "scripts": {
        "dev": "webpack-dev-server --open --mode development",
        "build": "webpack --mode production"
      },
    

    5.安装mini-css-extract-plugin插件

    npm install --save-dev mini-css-extract-plugin
    

    6.在webpack.config.js中中配置

    // 显示进程的完成进度
    var ProgressBarPlugin = require('progress-bar-webpack-plugin');
    // 设置进度字体颜色
    const chalk = require('chalk');
    // 以树图的方式展示打包后的文件
    const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;
    // 输出html
    const HtmlWebpackPlugin = require('html-webpack-plugin');
    // 分离css代码
    const MiniCssExtractPlugin = require('mini-css-extract-plugin');
    // 清空dist文件夹
    const {
      CleanWebpackPlugin
    } = require('clean-webpack-plugin');
    module.exports = {
      mode: 'production',
      entry: {
        app: './src/app.js'
      },
      output: {
        path: path.resolve(__dirname, '../dist'),
        filename: '[name].[hash].min.js'
      },
      module: {
        rules: [{
            test: /\.jsx?$/,
            use: [{
              loader: 'babel-loader'
            }]
          },
          {
            test: /\.css$/,
            use: [
              // {
              //   loader: 'style-loader'
              // },
              MiniCssExtractPlugin.loader,
              {
                loader: 'css-loader'
              },
              {
                loader: 'postcss-loader'
              }
            ]
          },
          {
            test: /\.less$/,
            use: [
              // {
              //   loader: 'style-loader'
              // },
              MiniCssExtractPlugin.loader,
              {
                loader: 'css-loader'
              },
              {
                loader: 'less-loader'
              }
            ]
          },
          {
            test: /\.scss$/,
            use: [
              // {
              //   loader: 'style-loader'
              // },
              MiniCssExtractPlugin.loader,
              {
                loader: 'css-loader'
              },
              {
                loader: 'postcss-loader'
              },
              {
                loader: 'sass-loader'
              }
            ]
          }
        ]
      },
      plugins: [
        new HtmlWebpackPlugin({
          title: 'Webpack Study Demo',
          filename: 'index.html', //指定生成的HTML文件名
          template: path.join(__dirname, '../public/index.html') // 指定模板路径
        }),
        
        new MiniCssExtractPlugin({
          filename: '[name].css',// 分离后的文件名
          chunkFilename: '[id].css',//
          ignoreOrder: false
        }),
        new CleanWebpackPlugin(),
        new ProgressBarPlugin({
          format: chalk.green('Progressing') + '[:bar]' + chalk.green(':percent') + '(:elapsed seconds)',
          clear: false
        }),
        new BundleAnalyzerPlugin()
      ]
    }
    

    7.运行命令

    npm run build
    

    8.结果展示


    相关文章

      网友评论

        本文标题:Webpack4.x 中CSS代码的分离

        本文链接:https://www.haomeiwen.com/subject/dtgujctx.html