webpack学习(十二):多页面提取公共部分(js&css)

demo地址: https://github.com/Lkkkkkkg/webpack-demo
继上一次配置完多页面 : https://blog.csdn.net/qq593249106/article/details/84933978

使用SplitChunksPlugin

The CommonsChunkPlugin 已经从 webpack v4 legato 中移除, webpack 4+ 版本使用内置的 SplitChunksPlugin 插件来进行公共部分的提取:

配置 webpack.config.js

因为 SplitChunksPlugin 是 webpack 4+ 版本内置的插件, 所以无需安装, 只需在 webpack.config.js 中配置

optimization: {
        splitChunks: {
            cacheGroups: {
                //打包公共模块
                commons: {
                    chunks: 'initial', //initial表示提取入口文件的公共部分
                    minChunks: 2, //表示提取公共部分最少的文件数
                    minSize: 0, //表示提取公共部分最小的大小
                    name: 'commons' //提取出来的文件命名
                }
            }
        }
    }

注意

还要在每一个页面的 HtmlWebpackPlugin 的 chunks 加上 commons, 因为提取之后的 commons 需要被打包出来的页面引用!

webpack.config.js

const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const CleanWebpackPlugin = require('clean-webpack-plugin');
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
var devMode = false; //标志是否开发模式
const OptimizeCssAssetsPlugin = require('optimize-css-assets-webpack-plugin');


module.exports = {
    mode: 'development',
    entry: { //入口文件
        index: "./src/components/index/index.js",
        otherA: "./src/components/otherA/otherA.js",
        otherB: "./src/components/otherB/otherB.js",
    },
    output: {
        path: path.join(__dirname, 'dist'),
        filename: 'js/[name].js', //根据入口文件分为不同出口文件
    },
    devtool: 'inline-source-map', // 不同选项适用于不同环境
    devServer: {
        contentBase: './dist', //将dist目录下的文件(index.html)作为可访问文件, 如果不写这个参数则默认与webpack.cofig.js的同级目录
        port: 8080 //端口号设为8080, 默认也是8080
    },
    module: {
        rules: [ //配置加载器, 用来处理源文件, 可以把es6, jsx等转换成js, sass, less等转换成css
            {
                exclude: /node_modules|packages/, //路径
                test: /\.js$/, //配置要处理的文件格式,一般使用正则表达式匹配
                use: 'babel-loader', //使用的加载器名称
            },
            {
                test: /\.(sa|sc|c)ss$/,
                use: [
                    devMode ? 'style-loader' : MiniCssExtractPlugin.loader,
                    'css-loader',
                    'sass-loader',
                ],
            },
        ]
    },
    plugins: [ //webpack 通过 plugins 实现各种功能, 比如 html-webpack-plugin 使用模版生成 html 文件
        new CleanWebpackPlugin(['dist']), //设置清除的目录
        new HtmlWebpackPlugin({
            template: "./src/components/index/index.html", //设置生成的HTML文件的名称, 支持指定子目录,如:assets/admin.html
            chunks: ['index', 'commons'], //指定入口文件
            filename: "index.html" //指定模板文件的位置
        }),
        new HtmlWebpackPlugin({
            template: "./src/components/otherA/otherA.html",
            chunks: ['otherA', 'commons'],
            filename: "otherA.html"
        }),
        new HtmlWebpackPlugin({
            template: "./src/components/otherB/otherB.html",
            chunks: ['otherB', 'commons'],
            filename: "otherB.html"
        }),
        new MiniCssExtractPlugin({
            filename: 'css/[name].css', //类似出口文件
            chunkFilename: 'css/[id].css'
        }),
        new OptimizeCssAssetsPlugin({
            assetNameRegExp: /\.css$/g, //一个正则表达式,指示应优化\最小化的资产的名称。提供的正则表达式针对配置中ExtractTextPlugin实例导出的文件的文件名运行,而不是源CSS文件的文件名。默认为/\.css$/g
            cssProcessor: require('cssnano'), //用于优化\最小化CSS的CSS处理器,默认为cssnano。这应该是一个跟随cssnano.process接口的函数(接收CSS和选项参数并返回一个Promise)。
            cssProcessorOptions: { safe: true, discardComments: { removeAll: true } }, //传递给cssProcessor的选项,默认为{}
            canPrint: true //一个布尔值,指示插件是否可以将消息打印到控制台,默认为true
        })
    ],
    optimization: {
        splitChunks: {
            cacheGroups: {
                //打包公共模块
                commons: {
                    chunks: 'initial', //initial表示提取入口文件的公共部分
                    minChunks: 2, //表示提取公共部分最少的文件数
                    minSize: 0, //表示提取公共部分最小的大小
                    name: 'commons' //提取出来的文件命名
                }
            }
        }
    }
};

这里修改一下目录结构, 在 src 新建一个 common 文件夹, common 文件夹下新建一个 css 文件夹, 专门用来放公共的 css 文件, 新建一个 common.scss 放入 css 文件夹中, 测试能否打包这个公共的 scss:
common.scss

$fontSize: 100px;

h1 {
  font-size: $fontSize;
}
|- /dist
  |- /css //分离出来的css文件
     |- index.css 
     |- otherA.css 
     |- otherB.css 
  |- /js
     |- index.js
     |- otherA.js
     |- otherB.js
  |- index.html
  |- otherA.html
  |- otherB.html
|- /node_modules
|- /src //用于放源文件的文件夹
  |- common //存放公共文件的目录
    |- css // 存放公共css的目录
      |- common.scss //公共css
   |- components //存放页面的目录
    |- index //主页
      |- App.js
      |- index.html 
      |- index.js
      |- index.scss
    |- otherA //另一个页面A
      |- App.js
      |- otherA.html 
      |- otherA.js
      |- otherA.scss
    |- otherB //另一个页面B
      |- App.js
      |- otherB.html 
      |- otherB.js
      |- otherB.scss
|- package.json
|- webpack.config.js //webpack配置文件

修改一下 index.js, otherA.js, otherB.js, 让它们都引入公共样式 common.scss:
index.js

import React from 'react'
import { render } from 'react-dom'
import App from './App'
import './index.scss'
import '../../common/common.scss'

render(<App />, document.getElementById("root"))

otherA.js

import React from 'react'
import { render } from 'react-dom'
import App from './App'
import './otherA.scss'
import '../../common/css/common.scss'

render(<App />, document.getElementById("root"))

otherB.js

import React from 'react'
import { render } from 'react-dom'
import App from './App'
import './otherB.scss'
import '../../common/css/common.scss'

render(<App />, document.getElementById("root"))

打包

终端输入 npm run build, 发现 dist 目录下的 css 和 js 文件夹分别多了 commons.css 和 commons.js, 而且其他 css 和 js 文件大小都变小了

|- /dist
  |- /css //分离出来的css文件
     |- commons.css 
     |- index.css 
     |- otherA.css 
     |- otherB.css 
  |- /js
     |- commons.js
     |- index.js
     |- otherA.js
     |- otherB.js
  |- index.html
  |- otherA.html
  |- otherB.html
|- /node_modules
|- /src //用于放源文件的文件夹
  |- common //存放公共文件的目录
    |- css // 存放公共css的目录
      |- common.scss //公共css
   |- components //存放页面的目录
    |- index //主页
      |- App.js
      |- index.html 
      |- index.js
      |- index.scss
    |- otherA //另一个页面A
      |- App.js
      |- otherA.html 
      |- otherA.js
      |- otherA.scss
    |- otherB //另一个页面B
      |- App.js
      |- otherB.html 
      |- otherB.js
      |- otherB.scss
|- package.json
|- webpack.config.js //webpack配置文件

打开 index.html, otherA.html, otherB.html:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
公共样式 h1{font-size:100px} 起了效果, 提取公共 js&css成功

猜你喜欢

转载自blog.csdn.net/qq593249106/article/details/84937856