ChatGPT解决这个技术问题 Extra ChatGPT

babel-loader jsx SyntaxError: Unexpected token [重复]

这个问题在这里已经有了答案:Babel 文件被复制而不被转换(10 个答案)5 年前关闭。

我是 React + Webpack 的初学者。

我在我的 hello world web 应用程序中发现了一个奇怪的错误。

我在 webpack 中使用 babel-loader 来帮助我将 jsx 转换为 js,但似乎 babel 无法理解 jsx 语法。

这是我的依赖项:

"devDependencies": {
  "babel-core": "^6.0.14",
  "babel-loader": "^6.0.0",
  "webpack": "^1.12.2",
  "webpack-dev-server": "^1.12.1"
},
"dependencies": {
  "react": "^0.14.1"
}

这是我的webpack.config.js

var path = require('path');
module.exports = {
  entry: ['webpack/hot/dev-server',path.resolve(__dirname, 'app/main.js')],
  output: {
    path: path.resolve(__dirname, 'build'),
    filename: 'bundle.js'
  },
  module: {
      loaders: [
          { test: /\.js$/, exclude: /node_modules/, loader: "babel-loader"}
      ]
  }
};

这是我的app/main.js

var React = require("react");
React.render(<h1>hello world</h1>,document.getElementById("app"));

这是错误信息

ERROR in ./app/main.js
Module build failed: SyntaxError: ~/**/app/main.js: Unexpected token (2:13)
  1 | var React = require("react");
> 2 | React.render(<h1>hello world</h1>,document.getElementById("app"));
    |              ^
at Parser.pp.raise (~/**/node_modules/babylon/lib/parser/location.js:24:13)

谢谢你们。

<h1> 后面的逗号看起来有点奇怪……
对于较新版本的 react ,请使用新的 babel 模块:stackoverflow.com/a/53927457/6665568。它有更好的错误信息并支持 react 的新特性。

L
Liran H

添加“babel-preset-react”

npm install babel-preset-react

并在 webpack.config.js 中为 babel-loader 添加“预设”选项

(或者您可以将其添加到您的 .babelrc 或 package.js:http://babeljs.io/docs/usage/babelrc/

这是一个示例 webpack.config.js:

{ 
    test: /\.jsx?$/,         // Match both .js and .jsx files
    exclude: /node_modules/, 
    loader: "babel", 
    query:
      {
        presets:['react']
      }
}

最近 Babel 6 发布了,有一个重大变化:https://babeljs.io/blog/2015/10/29/6.0.0

如果您使用的是 react 0.14,则应使用 ReactDOM.render()(来自 require('react-dom'))而不是 React.render()https://facebook.github.io/react/blog/#changelog

2018 年更新

Rule.query 已被弃用,取而代之的是 Rule.options。 webpack 4 中的用法如下:

npm install babel-loader babel-preset-react

然后在你的 webpack 配置中(作为 module.exports 对象中 module.rules 数组中的一个条目)

{
    test: /\.jsx?$/,
    exclude: /node_modules/,
    use: [
      {
        loader: 'babel-loader',
        options: {
          presets: ['react']
        }
      }
    ],
  }

另一个问题,如果我以后想使用 ES6 语法,我应该安装 babel-preset-es2015 并以同样的方式在配置文件中做一些选项吗?
你说对了。 presets:['es2015','react']
我正在尝试遵循这一点,但我仍然收到错误消息。你能发布一个完整的package.json,和webpack.config.js,main.js“hello world”吗?
我不知道为什么,但似乎顺序很重要:presets:['es2015','react'] 我正在尝试使用 presets:['react','es2015'] 并且它失败了
s
svnm

从 babel 5 迁移到 babel 6 时,我遇到了类似的问题。

我只是在运行 babel 将 src 编译到 lib 文件夹 babel src --out-dir lib

我将分享我对 babel 6 的设置:

确保您安装了以下 babel 6 devDependencies

"babel-core": "^6.7.6",
"babel-loader": "^6.2.4",
"babel-preset-es2015": "^6.6.0",
"babel-preset-react": "^6.5.0",
"babel-preset-stage-0": "^6.5.0"

将你的 .babelrc 文件添加到项目中:

{
  "presets": ["es2015", "stage-0", "react"]
}

使用 stage-0 时对 es2015 的需求是一个很大的问题。
export App from './App' 出现未知语法错误 - 意识到我需要 stage-0,谢谢。
我有一个用于 react、babel 和 webpack here 的示例设置,它还包括用于测试 css 模块和通用渲染的酶。
这在没有阶段 0 的情况下对我有用
这个对我有用。我在 devDependencies 中没有 stage-0。
C
Community

由于上面的答案仍然使 some people 处于黑暗中,因此完整的 webpack.config.js 可能如下所示:

var path = require('path'); var config = { entry: path.resolve(__dirname, 'app/main.js'), output: { path: path.resolve(__dirname, 'build'), filename: 'bundle.js' }, module: { loaders : [{ test: /\.jsx?$/, loader: 'babel', query: { presets:['es2015', 'react'] } }] }, }; module.exports = 配置;


a
albanx

对我来说,解决方案是使用以下内容创建文件 .babelrc

{
  "presets": ["react", "es2015", "stage-1"]
}

u
ubuntugod

以下方式帮助了我(包括 react-hot、babel loader 和 es2015、react presets):

loaders: [
      {
        test: /\.jsx?$/,
        exclude: /node_modules/,
        loaders: ['react-hot', 'babel?presets[]=es2015&presets[]=react']
      }
]

当我在此链接中关注 Django plus React 内容时,这对我有所帮助:owaislone.org/blog/webpack-plus-reactjs-and-django 这是(我认为)使用上述 .babelrc 文件的替代方法。
即使我的错误与原始问题不同,这也对我有所帮助。
我不得不删除 '?presets[]=es2015&presets[]=react'。在 .babelrc 中添加 'state-0' 有助于解决问题。
A
Aftab Naveed

对于那些仍然可能面临添加 jsx 来测试的问题的人,为我修复了它

test: /\.jsx?$/,

从字面上看,几天来我一直在尝试通过对 gulpfile.js 的每一个可能的更改来解决这个问题,......就这么简单
j
jose920405

这对我来说很完美

{
    test: /\.(js|jsx)$/,
    loader: 'babel-loader',
    exclude: /node_modules/,
    query: {
        presets: ['es2015','react']
    }
},

M
Maxime Brehin

您可以在此处找到 Henrik Joreteg (ampersandjs) 制作的非常好的样板:https://github.com/HenrikJoreteg/hjs-webpack

然后在您的 webpack.config.js

var getConfig = require('hjs-webpack')

module.exports = getConfig({
  in: 'src/index.js',
  out: 'public',
  clearBeforeBuild: true,
  https: process.argv.indexOf('--https') !== -1
})

关注公众号,不定期副业成功案例分享
关注公众号

不定期副业成功案例分享

领先一步获取最新的外包任务吗?

立即订阅