【发布时间】:2016-07-30 01:07:03
【问题描述】:
我正在尝试直接从 node_modules 加载较少的文件,特别是“react-widgets”库。我按照their site 的指示设置了一个非常简单的示例,将其转换为basic template。令我沮丧的是,我收到以下错误消息:
D:\GitHub\react-webpack-template\node_modules\react-widgets\lib\less\react-widgets.less:1
(function (exports, require, module, __filename, __dirname) { @import "./variables.less";
^
SyntaxError: Unexpected token ILLEGAL
at Object.exports.runInThisContext (vm.js:53:16)
at Module._compile (module.js:513:28)
at Object.Module._extensions..js (module.js:550:10)
at Module.load (module.js:458:32)
at tryModuleLoad (module.js:417:12)
at Function.Module._load (module.js:409:3)
at Module.require (module.js:468:17)
at require (internal/module.js:20:19)
at Object.<anonymous> (D:\GitHub\react-webpack-template\webpack.config.js:4:1)
at Module._compile (module.js:541:32)
它抱怨文件开头的@import。这是有效的 Less,所以我很确定它是 Babel 干扰,但我不确定如何让它忽略我的 .less 文件。
这是我的 webpack 配置
require('react-widgets/lib/less/react-widgets.less')
module.exports = {
entry: './index',
output: {
filename: 'browser-bundle.js'
},
devtool: 'source-map',
module: {
loaders: [
{
test: /\.js$/,
loader: 'babel-loader',
query: {
presets: ['es2015', 'react']
}
},
{ test: /\.css$/, loader: 'style-loader!css-loader' },
{ test: /\.less$/, loader: 'style-loader!css-loader!less-loader' },
{ test: /\.gif$/, loader: "url-loader?mimetype=image/png" },
{ test: /\.woff(2)?(\?v=[0-9].[0-9].[0-9])?$/, loader: "url-loader?mimetype=application/font-woff" },
{ test: /\.(ttf|eot|svg)(\?v=[0-9].[0-9].[0-9])?$/, loader: "file-loader?name=[name].[ext]" },
]
}
};
我尝试过类似的 SO 响应,但仍然让我摸不着头脑。
我还应该尝试什么?
【问题讨论】:
标签: reactjs less ecmascript-6 webpack