我使用最新版本的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,
}),
],
};
答案 0 :(得分:0)
为什么你不使用从Sass到CSS的外部编译器,它会更快更容易,你只需在你的webpack配置中使用CSS加载器, 你有多个程序编译器从sass到css,如(compass,Prepros) Prepros非常好, 我用这种方式并且没有任何问题