Webpack с babel-загрузчиком, не признающим ключевое слово import
У меня есть webpack.config.js
:
module.exports = {
entry: './src/admin/client/index.jsx',
output: {
filename: './src/admin/client/static/js/app.js'
},
loaders: [
{
test: /\.jsx?$/,
loader: 'babel',
exclude: /node_modules/,
query: {
optional: ['runtime']
}
}
],
resolve: {
extensions: ['', '.js', '.jsx']
}
};
... но я все еще получаю эту ошибку:
$ webpack -v
Hash: 2a9a40224beb025cb433
Version: webpack 1.10.5
Time: 44ms
[0] ./src/admin/client/index.jsx 0 bytes [built] [failed]
ERROR in ./src/admin/client/index.jsx
Module parse failed: /project/src/admin/client/index.jsx Line 1: Unexpected reserved word
You may need an appropriate loader to handle this file type.
| import React from 'react';
| import AdminInterface from './components/AdminInterface';
У меня есть:
- Установлен
webpack
глобально и локально
- Установленные
babel-loader
, babel-core
и babel-runtime
- Установлен
babel-loader
глобально, на всякий случай
Почему, черт возьми, webpack, казалось бы, игнорирует babel-loader
? Или babel-loader
не работает с модулями?
Обновление
Похоже, что babel
отлично обрабатывает входной файл. Когда я запускаю:
./node_modules/babel/bin/babel.js ./src/admin/client/index.jsx
... он выводит ES5, как ожидалось. Поэтому мне кажется, что как-то webpack
неправильно загружается babel-loader
.
Ответы
Ответ 1
Это выглядит как случай ошибки оператора. Моя структура webpack.config.js
неверна. В частности, мне нужно было разместить детали загрузчика внутри раздела module
:
module.exports = {
entry: './src/admin/client/index.jsx',
output: {
filename: './src/admin/client/static/js/app.js'
},
module: {
loaders: [
{
test: /\.jsx?$/,
loader: 'babel',
exclude: /node_modules/,
query: {
optional: ['runtime']
}
}
],
resolve: {
extensions: ['', '.js', '.jsx']
}
}
};
Ответ 2
Я исправил ту же проблему, включив es2015 и отредактировать пресеты, а затем добавив их в файл webpack.config.js.
npm install --save-dev babel-preset-es2015
npm install --save-dev babel-preset-react
как описано в этом сообщении: https://www.twilio.com/blog/2015/08/setting-up-react-for-es6-with-webpack-and-babel-2.html
мой полный файл webpack.config.js:
module.exports = {
context: __dirname + "/src",
entry: './main',
output: {
path: __dirname + "/build",
filename: "bundle.js"
},
module: {
loaders: [
{
test: /\.js$/,
exclude: /node_modules/,
loader: "babel-loader",
query: {
presets: ['es2015', 'react']
}
}
],
resolve: {
extensions: ['.js', '.jsx']
}
}
};
Ответ 3
Какова версия вашего Babel? Если версия для Babel - до 6+. Вам нужно идентифицировать предустановку "es2015" и "реагировать", как это.
module: {
loaders: [
{
test: /\.jsx?$/,
exclude: /(node_modules|bower_components)/,
loader: 'babel', // 'babel-loader' is also a legal name to reference
query: {
presets: ['react', 'es2015']
}
}
]
}
Не забудьте установить эти модули:
npm install babel-loader babel-core babel-preset-es2015 babel-preset-react --save-dev