CSS中的Webpack Uglify错误

Webpack Uglify errors in CSS

本文关键字:错误 Uglify Webpack 中的 CSS      更新时间:2023-09-26

我很紧张,试图让Uglify与我的项目一起工作,以前我使用过Uglify,没有出现问题,但现在我认为这与SASS有关。

ERROR in ./~/css-loader!./~/sass-loader!./app/scss/global-header.scss
    Module build failed: TypeError: Cannot read property '4' of undefined
        at reduce (/Users/contractor/centralefcom-global-components/node_modules/postcss-reduce-transforms/dist/index.js:121:23)
        at walk (/Users/contractor/centralefcom-global-components/node_modules/postcss-value-parser/lib/walk.js:7:22)
        at ValueParser.walk (/Users/contractor/centralefcom-global-components/node_modules/postcss-value-parser/lib/index.js:18:5)
        at /Users/contractor/centralefcom-global-components/node_modules/postcss-reduce-transforms/dist/index.js:131:75
        at /Users/contractor/centralefcom-global-components/node_modules/postcss/lib/container.js:92:28
        at /Users/contractor/centralefcom-global-components/node_modules/postcss/lib/container.js:73:26
...
...

这个错误重复了很多次,每个多束重复一次。

这是我的webpack配置。

var webpack = require('webpack')
var HtmlWebpackPlugin = require('html-webpack-plugin');
var ExtractTextPlugin = require('extract-text-webpack-plugin');
var path = require('path');
module.exports = {
  context: __dirname,
  resolve: {
    modulesDirectories: ['node_modules', 'bower_components']
  },
  entry: {
    'all': [
      './app/global-all.js',
      './app/scss/global-all.scss'
    ],
    'footer': [
      './app/global-footer.js',
      './app/scss/global-footer.scss'
    ],
    'header': [
      './app/global-header.js',
      './app/scss/global-header.scss'
    ],
    'footer.nodeps': [
      './app/global-footer-nodeps.js',
      './app/scss/global-footer-nodeps.scss'
    ],
    'header.nodeps': [
      './app/global-header-nodeps.js',
      './app/scss/global-header-nodeps.scss'
    ],
  },
  output: {
    path: path.join(__dirname, 'dist'),
    filename: 'js/global.[name].js',
  },
  module: {
    loaders: [
      {
        test: /'.scss$/,
        loader: ExtractTextPlugin.extract('style','css!sass!')
      },
      {
        test: /'.(woff|woff2|ttf|eot|svg)('?v=[0-9]'.[0-9]'.[0-9])?$/,
        loader: 'file?name=/assets/[name].[ext]'
      },
      {
        test: /'.(jpg|jpeg|png)$/,
        loader: 'file?name=/assets/[name].[ext]'
      }
    ],
  },
  plugins: [
    new webpack.EnvironmentPlugin([
      'NODE_ENV'
    ]),
    new ExtractTextPlugin('css/global.[name].css'),
    new HtmlWebpackPlugin({
      template: 'underscore-template-loader!./app/views/secondary.html',
      inject: false,
      filename: 'secondary.html'
    }),
        new HtmlWebpackPlugin({
      template: 'underscore-template-loader!./app/views/secondary-transparent.html',
      inject: false,
      filename: 'secondary-transparent.html'
    }),
    new HtmlWebpackPlugin({
      template: 'underscore-template-loader!./app/views/secondary-academy.html',
      inject: false,
      filename: 'secondary-academy.html'
    }),
    new HtmlWebpackPlugin({
      template: 'underscore-template-loader!./app/views/hero-stage.html',
      inject: false,
      filename: 'hero-stage.html'
    }),
    // Only minify in build, check npm tasks
    new webpack.optimize.UglifyJsPlugin({
      sourceMap: false,
      mangle: false
    }),
    ]
};

如果我评论uglifyJsPlugin行,没有错误。但我必须做缩小,没有办法让它运行,我尝试了mangler:假的,什么都没有,不起作用。

您正试图通过不支持的UglifyJs插件传递CSS文件。

为了只丑化你的JS源代码,你可以根据文件扩展名进行过滤。

下面的示例将仅包含扩展名为.js.jsx的Uglify文件:

new webpack.optimize.UglifyJsPlugin({
  sourceMap: false,
  mangle: false,
  test: /'.(js|jsx)$/
})

您将SCSS文件作为入口点的一部分。在webpack中,更常见的做法是在JS文件中要求您需要的文件(SCSS方面)。

// Here, the ExtractTextPlugin will use sass-loader to extract and compile styles
require('styles.scss');
// The rest of your code goes here
// For instance, app.js
function someCode() {
    document.body.style.backgroundColor = 'blue';
}

然后设置sass加载程序来检测和处理那些require语句,这些语句已经用下面的加载程序完成了。

{
    test: /'.scss$/,
    loader: ExtractTextPlugin.extract('style','css!sass!')
}