このエラーは、このチュートリアルに従って配列にreact-hot
ローダーを追加した後に発生しました。 https://thoughtbot.com/blog/setting-up-webpack-for-react-and-hot-module-交換
Error: Cannot define 'query' and multiple loaders in loaders list
を取得しています。
var WebpackDevServer = require("webpack-dev-server");
var webpack = require('webpack');
var path = require('path');
require("babel-polyfill");
var BUILD_DIR = path.resolve(__dirname, 'build');
var APP_DIR = path.resolve(__dirname, 'src');
module.exports = {
entry: [
'babel-polyfill',
'bootstrap-loader',
'webpack/hot/dev-server',
APP_DIR + '/import.js',
],
output: {
path: BUILD_DIR,
filename: 'bundle.js'
},
module: {
loaders: [{
test: /\.jsx?$/,
loaders: ['react-hot', 'babel'],
exclude: /node_modules/,
query: {
plugins: ['transform-runtime'],
presets: ['es2015', 'stage-0', 'react']
}
}, {
test: /\.css$/,
loader: "style-loader!css-loader"
}, {
test: /\.scss$/,
loaders: ["style", "css", "sass"]
}, {
test: /\.(png|woff|woff2|eot|ttf|svg|jpg|gif)$/,
loader: 'url-loader?limit=100000'
}]
},
plugins: [
new webpack.ProvidePlugin({
$: "jquery",
jQuery: "jquery"
}),
new webpack.HotModuleReplacementPlugin(),
new webpack.NoErrorsPlugin()
]
};
クエリは、singleローダーの動作をカスタマイズする代替方法であり、インラインでこれらのパラメーターを指定するよりもクリーンであるようです(以下を参照)。複数のローダーが存在する場合、Webpackはquery
構成の適用先を認識しません。
以下が問題を解決するはずです。
module: {
loaders: [{
test: /\.jsx?$/,
exclude: /node_modules/,
loaders: ['react-hot', 'babel?presets[]=es2015,presets[]=stage-0,presets[]=react,plugins[]=transform-runtime']
}
編集:このソリューションはWebpack 1で機能しますが、より新しいバージョンで機能するよりクリーンなソリューションに関する他の回答を参照してください。
私のソリューション:
loaders: [{
test: /\.(js|jsx)$/,
loaders: ['react-hot', 'babel?' + JSON.stringify({
cacheDirectory: true,
plugins: [
'transform-runtime',
'transform-decorators-legacy'
],
presets: ['es2015', 'react', 'stage-0'],
env: {
production: {
presets: ['react-optimize']
}
}
}), 'eslint'],
include: src,
exclude: /node_modules/
}
webpack 2&では、これをよりきれいに構成できます。
ローダーは、ローダーオブジェクトの配列で渡すことができます。各ローダーオブジェクトは、特定のローダーのwebpack 1 options
のように動作するquery
オブジェクトを指定できます。
たとえば、react-hot-loader
とbabel-loader
の両方を使用し、babel-loader
をwebpack 2/でいくつかのオプションで設定します
module: {
rules: [{
test: /\.js$/,
exclude: /node_modules/,
use: [{
loader: 'react-hot-loader'
}, {
loader: 'babel-loader',
options: {
babelrc: false,
presets: [
'es2015-native-modules'
'stage-0',
'react'
]
}
}]
}]
}
比較のため、クエリ文字列メソッドを使用したwebpack 1の同じ設定を次に示します。
module: {
rules: [{
test: /\.js$/,
exclude: /node_modules/,
loaders: [
'react-hot',
'babel-loader?' +
'babelrc=false,' +
'presets[]=es2015,' +
'presets[]=stage-0,' +
'presets[]=react'
]
}]
}
変更されたプロパティ名がチェーン全体にあることに注意してください。
また、es2015
構成でes2015-native-modules
プリセットをbabel-loader
プリセットに変更したことに注意してください。これはoptions
の指定とは関係ありません。es6モジュールを含めることで、v2で導入されたwebpackツリーシェーキング機能を使用できるようになります。そのままにしておくこともできますが、その明らかなアップグレードが指摘されていなければ、答えは不完全に感じられます:-)
免責事項:これは 類似の質問 に対する私の回答と同じですが、この質問には類似した票数/ビュー数/グーグルランキングがあるため、ここにも回答を掲載します。
webpack 2の場合。私はこのように設定することができます:
var webpack = require("webpack");
var path = require("path");
module.exports = {
entry: "./src/index.js",
output: {
path: path.resolve(__dirname, "dist/assets"),
filename: "bundle.js",
publicPath: "/assets/"
},
devServer: {
inline: true,
contentBase: './dist',
port: 3000
},
module: {
loaders: [
{
test: /\.js$/,
exclude: /(node_modules)/,
loader: "babel-loader",
options: {
presets: ['latest', 'react', 'stage-0']
}
}
]
}
};
自分で解決策を見つけてから、同じ問題に直面していました。あなたはそれを試すことができます:
「.babelrc」ファイルで「プリセット」を定義している場合は、「webpack.config.js」ファイルで指定する必要はありません。その後、削除して正常に機能します
そうでない場合は、「。babelrc」ファイルに移動して、そこにプリセットを指定することをお勧めします
このソリューションは私のために働いた:
module: {
loaders:[
{
test: /\.js$/,
exclude: /(node_modules)/,
loader: 'babel-loader'
}
]
}
.babelrcのプリセット
{
'presets': ['latest', 'react', 'stage-0']
}