web-dev-qa-db-ja.com

ReactJSモジュールのビルドに失敗しました:SyntaxError:予期しないトークン-ReactDOM.render

以下にこのエラーが表示されるのはなぜですか?私のステートメントReactDOM.render(<App />, container);は100%合法的なコードです。

私のgithubリポジトリ: https://github.com/leongaban/react_starwars

enter image description here

App.jsファイル

import react from 'react'
import ReactDom from 'react-dom'
import App from 'components/App'

require('index.html');

// Create app
const container = document.getElementById('app-container');

// Render app
ReactDOM.render(<App />, container);

Components/Appファイル

import React from 'react'

const App = () =>
  <div className='container'>
    <div className='row'>

    </div>
    <div className='row'>

    </div>
  </div>;

export default App; 

私のwebpack.config

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

module.exports = {
entry: [
  './src/app.js'
],
output: {
  path: path.resolve(__dirname, './build'),
  filename: 'app.bundle.js',
},
module: {
  loaders: [
    {
      test: /\.html$/,
      loader: 'file-loader?name=[name].[ext]',
    },
    {
      test: /\.jsx?$/,
      exclude: /node_modules/,
      loader: 'babel-loader',
    },
  ],
},
plugins: [
  new webpack.NamedModulesPlugin(),
]
};
17
Leon Gaban

これをwebpack構成ファイルとして使用します

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

module.exports = {
    entry: [
        './src/app.js'
    ],
    output: {
        path: path.resolve(__dirname, './build'),
        filename: 'app.bundle.js',
    },
    module: {
        loaders: [
            {
                test: /\.html$/,
                loader: 'file-loader?name=[name].[ext]',
            },
            {
                test: /\.jsx?$/,
                exclude: /node_modules/,
                loader: 'babel-loader',
            query: {
                presets: ['es2015', 'react']
            }
        },
    ],
},
plugins: [
    new webpack.NamedModulesPlugin(),
]
};

プリセットがありません

14
Julien

私は同じエラーを受け取っていたので、次を含むプロジェクトのルート(package.jsonと同じ場所)に.babelrcファイルを追加するだけでした。

{
    "presets": [
        "env", 
        "react"
    ],
    "plugins": [
        "transform-class-properties"
    ]
}
12
Andy Smith

Jsx構文のbabel-preset-reactをインストールします。

npm install babel-preset-react

プリセット

loaders: [{
            test: /\.jsx?$/,
            exclude: /node_modules/,
            loader: 'babel-loader',
            query: {
                presets: ['react', 'es2015']
            }
        }
    ]
5
Sridhar

または、プロジェクトのルートにある.babelrcファイルにプリセットを配置できます。もちろん、最初にインストールする必要があります。

このような /path/to/your/project/.babelrc

{ "presets": ["@babel/preset-env", "@babel/preset-react"] }

1
Yury Lavrukhin

resolveプロパティをwebpack設定ファイルに追加してみてください:

    resolve: {
        extensions: ['.js', '.jsx']
    },
    module: {
        loaders: [
            {
                test: /\.jsx?$/,
                exclude: /node_modules/,
                loaders: ["babel-loader"]
            }
        ]
    }
1
Daniel Pérez

誰かがCRAで作業していて、このエラーが発生した場合。ここに解決策があります。

Goto package.jsonおよびbabel configを追加します。私がそれほど寛大に見えないなら、以下はコードです

 "babel": {
        "presets": [
            "react-app"
        ]
 }

CRAセットアップの残りの部分はそのままにします。実際、CRAは独自のカスタムプリセットを使用しますreact-appそして、それがwebpack.config.jsファイル。したがって、他のプリセットは必要ありません。

0
kushalvm