React 项目中使用 Babel 解析 ES6 代码时出现 `Unexpected token...jump` 是什么原因呢?

阅读时长 2 分钟读完

背景

在开发 React 项目时,我们通常使用 Babel 来将 ES6+ 语法编译成可在浏览器中执行的 ES5 语法。然而,有时我们会遇到这样的错误信息:"Unexpected token...jump"。这个错误信息通常会伴随着一个错误位置(line 和 column)。那么,这个错误是什么原因引起的呢?又该如何解决呢?

原因

在 ES6 中,我们可以使用扩展运算符 ... 来将一个数组或者类数组转换成一个拆分后的参数序列。例如:

然而,当我们在使用对象字面量时,如果在对象字面量中使用了扩展运算符 ...,并且 ... 后面跟着一个 jump 关键字,那么就会出现上述错误信息:

这是因为,对象字面量中的 ... 表示“展开”一个对象,而 jump 并不是一个合法的对象,因此会导致 Babel 编译时出现语法错误。

解决方案

有以下两种解决方案:

  1. 在对象字面量中不使用扩展运算符 ...,而是使用 Object.assign 方法:
  1. 升级 Babel 编译器版本到 7.10.0 及以上,新版 Babel 已经对这种语法进行了支持。

总结

在 React 项目中使用 Babel 解析 ES6 代码时,如果遇到了 "Unexpected token...jump" 这样的错误信息,那么可能是在对象字面量中使用了扩展运算符 ...,并且 ... 后面跟着了一个非法的关键字,而这种语法在较老版本的 Babel 中可能不被支持。解决方案是升级 Babel 编译器版本到 7.10.0 及以上,或者避免在对象字面量中使用扩展运算符 ...

来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/64fc393df6b2d6eab32140ad

纠错
反馈