Webpack: файл SCSS в CSS - PullRequest
       5

Webpack: файл SCSS в CSS

1 голос
/ 19 октября 2019

Как мне взять мой исходный код SCSS и скомпилировать его в (бонус: минимизированный) файл CSS?

Одна вещь, которую ясно дает чтение документации и поиск в Интернете, это то, что каждый, кажется, готовит свои собственныеСуп, нет стандартного / рекомендуемого способа для такой общей задачи.

Ответы [ 2 ]

0 голосов
/ 20 октября 2019

Ниже приведен минимальный пример, который работал для меня:

package.json:

{
  …
  "devDependencies": {
    "css-loader": "^3.2.0",
    "mini-css-extract-plugin": "^0.8.0",
    "node-sass": "^4.12.0",
    "optimize-css-assets-webpack-plugin": "^5.0.3",
    "sass-loader": "^8.0.0",
    "webpack": "^4.40.2",
    "webpack-cli": "^3.3.9"
  }
}

webpack.config.js:

const path = require("path");
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
const OptimizeCssAssetsPlugin = require('optimize-css-assets-webpack-plugin');

module.exports = {
  …
  module: {
    rules: [
      { // CSS assets remaining in the pipeline (e.g. frameworks)
        test: /\.css$/,
        use: [
          "style-loader", // or e.g. "vue-style-loader" etc. (optional)
          MiniCssExtractPlugin.loader,
          "css-loader"
        ]
      },
      { // SCSS
        test: /\.scss$/,
        use: [
          "style-loader" // (optional)
          MiniCssExtractPlugin.loader,
          "css-loader",
          "sass-loader"
        ]
      }
    ]
  },

  // Plugins
  plugins: [
    new MiniCssExtractPlugin({
      filename: "./css/my-style.css" // relative to `output.path` by default
    }),
    new OptimizeCssAssetsPlugin() // construction suffices, no additional calls needed
  ]
};

Модуль node-sass уже выводит минимизированный CSS, поэтому, если вы знаете , вы не встретите ни одного необработанного CSS в своем проекте, вы можете избавиться от OptimizeCssAssetsPlugin.

0 голосов
/ 19 октября 2019

Это то, что я сделал здесь

Сначала я преобразую свой файл scss в файл css, используя этот параметр в веб-пакете

module: {
        rules: [{
                test: /\.scss$/,
                use: [
                    'style-loader',
                    MiniCssExtractPlugin.loader,
                    {
                        loader: "css-loader",
                        options: {
                            minimize: true,
                            sourceMap: true
                        }
                    },
                    {
                        loader: "sass-loader"
                    }
                ]
            }
        ]
    }

Затем я используюwebpack-shell-plugin для запуска команды postcss для минимизации css-файла. (Бонус, я также добавляю gzip, используя плагин Compression для преобразования css в gzip)

plugins: [
        new CompressionPlugin({
            test: /\.(js|css)/
        }),
        new WebpackShellPlugin({
            onBuildStart: ['echo "Starting postcss command"'],
            onBuildEnd: ['postcss --dir wwwroot/dist wwwroot/dist/*.css']
        })
    ],
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...