mini-css-extract-plugin如何去重

发布于 2022-09-11 22:13:51 字数 1739 浏览 22 评论 0

我想自己从零搭建vue项目,顺便学习webpack,但是在打包css遇到在不同文件下引入相同的css,在打包的时候回重复打包文件。如:在main.js中引入app.scss再在app.vue中引入app.scss,打包出来的css就像下面

div {
  font-size: 29px;
  height: 200px; }
div {
  font-size: 29px;
  height: 200px;
}

webpack配置

const webpack = require("webpack")
const path = require("path")
const HTMLWebpackPlugin = require("html-webpack-plugin")
const VueLoaderPlugin = require('vue-loader/lib/plugin')
const MiniCssExtractPlugin = require('mini-css-extract-plugin');


module.exports = {
  // 确认环境是生产环境或开发环境
  mode: "development",
  // 入口文件
  entry: "./src/index.js",
  // 文件输出配置
  output: {
    // 文件打包输出路径
    path: path.resolve(__dirname, 'dist'),
    // 文件打包输出的名字
    filename: "[name].js"
  },
 devServer: {
    port: 3000,
  },
  module: {
    rules: [
      {
        test: /\.css$/,
        use: [{
          loader: MiniCssExtractPlugin.loader
        }, "css-loader"]
      },
      {
        test: /\.vue$/,
        use: ["vue-loader"]
      },
      {
        test: /\.(jpg|png|gif)$/i,
        use: [{
          loader: "url-loader",
          options: {
            limit: false,
          }
        }]
      },
      {
        test: /\.scss$/,
        use: [
          {
            loader: MiniCssExtractPlugin.loader
          },
          "css-loader", "sass-loader"]
      }
    ]
  },
  plugins: [
    new HTMLWebpackPlugin({
      // 生成html文件名
      filename: "index.html",
      // 要进行编译的html
      template: "./src/index.html"
    }),
    // vue-loader插件配置
    new VueLoaderPlugin(),
    // 将css打包抽离
    new MiniCssExtractPlugin(
      {
        filename: "./css/[name].css",
        chunkFilename: '[id].css',
      }
    )
  ]
}

在网上找了很久也没有到达答案,求教!!!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文