建立后Webpack 3 sass loader错误

时间:2017-08-04 16:56:02

标签: webpack sass webpack-dev-server extract-text-plugin extracttextwebpackplugin

我使用最新版本的webpack 3.4.1使用sass loader和extract text插件从sass源生成静态css文件。它在我的开发服务器上加载很好,我可以看到css文件,但是在第一行指向css文件@ body {color:#000}时出现控制台错误'Uncaught SyntaxError:Unexpected token'。

我的webpack配置如下。任何帮助非常感谢。

const path = require('path');
const webpack = require('webpack');

const ExtractTextPlugin = require('extract-text-webpack-plugin');

module.exports = {
  context: path.resolve(__dirname, ''),
  entry: {
    app: './src/js/app.js',
  },
  output: {
    filename: '[name].bundle.js',
    path: path.resolve(__dirname, './dist/assets'),
    publicPath: '/assets',
  },
  devServer: {
    contentBase: path.resolve(__dirname, './src'), // New
  },
  module: {
    rules: [{
        test: /\.js$/,
        exclude: [/node_modules/],
        use: [{
          loader: 'babel-loader',
          options: {
            presets: ['es2015']
          },
        }],
      },
      {
        test: /\.(svg|gif|png|eot|woff|ttf)$/,
        use: [{
          loader: 'url-loader'
        }]
      },
      {
        test: /\.scss$/,
        use: ExtractTextPlugin.extract({
          fallback: 'style-loader',
          use: ['css-loader', 'sass-loader']
        })
      }
    ],
  },
  plugins: [
    new ExtractTextPlugin({
      filename: '[name].bundle.css',
      allChunks: true,
    }),
  ],
};

1 个答案:

答案 0 :(得分:0)

为什么你不使用从Sass到CSS的外部编译器,它会更快更容易,你只需在你的webpack配置中使用CSS加载器, 你有多个程序编译器从sass到css,如(compass,Prepros) Prepros非常好, 我用这种方式并且没有任何问题