SyntaxError: 尝试使用 @babel/register 时意外的令牌导出
Posted
技术标签:
【中文标题】SyntaxError: 尝试使用 @babel/register 时意外的令牌导出【英文标题】:SyntaxError: Unexpected token export when trying to use @babel/register 【发布时间】:2019-07-05 11:22:51 【问题描述】:当尝试使用 Babel 运行节点并做出反应时,@babel/register 不起作用
我在 SO 上查看了类似的问题,重新安装了节点 10.15.1,升级到最新版本 11.9。
下面是package.json中的相关依赖:
"dependencies":
"@babel/core": "7.1.6",
"@babel/polyfill": "^7.2.5",
"@babel/register": "^7.0.0",
"@svgr/webpack": "2.4.1",
"babel-core": "7.0.0-bridge.0",
"babel-jest": "23.6.0",
"babel-loader": "8.0.4",
"babel-plugin-named-asset-import": "0.3.0",
"babel-preset-react-app": "7.0.0",
"react": "16.7.0",
"react-app-polyfill": "0.2.0",
"react-dev-utils": "7.0.1",
"react-dom": "16.7.0",
"resolve": "1.8.1",
"webpack": "4.19.1",
"webpack-dev-server": "3.1.14",
"webpack-manifest-plugin": "2.0.4",
"workbox-webpack-plugin": "3.6.3"
尝试执行本教程中关于使用 react 运行 s-s-r 的内容。 我的 index.js 看起来像这样:
require('@babel/polyfill');
require('@babel/register')(
ignore: [/\/(build|node_modules)\//,
],
presets: ['@babel/preset-env','@babel/preset-react'],
plugins: [
'@babel/plugin-syntax-dynamic-import',
'dynamic-import-node',
]
);
require('./server');
server.js
import express from 'express';
import path from 'path';
import React from 'react';
import renderToString from 'react-dom/server';
import App from '../src/App'
const app = express();
const PORT = process.env.PORT || 3000;
const router = express.Router()
const serverRenderer = (req, res, next) =>
fs.readFile(path.resolve('./build/index.html'), 'utf8', (err, data) =>
if (err)
console.error(err)
return res.status(500).send('An error occurred')
return res.send(
data.replace(
'<div id="root"></div>',
`<div id="root">$ReactDOMServer.renderToString(<App />)</div>`
)
)
)
router.use('^/$', serverRenderer)
router.use(
express.static(path.resolve(__dirname, '..', 'build'), maxAge: '30d' )
)
// tell the app to use the above rules
app.use(router)
app.listen(PORT, () =>
console.log(`s-s-r running on port $PORT`)
)
当像这样从 CLI 运行时:
npm run build
cross-env NODE_ENV=production node server/index.js
我一直收到此错误:
/Users/myfolder/workspace/webapp/node_modules/@babel/runtime/helpers/esm/classCallCheck.js:1
(function (exports, require, module, __filename, __dirname) export default function _classCallCheck(instance, Constructor)
^^^^^^
SyntaxError: Unexpected token export
at new Script (vm.js:84:7)
at createScript (vm.js:264:10)
at Object.runInThisContext (vm.js:312:10)
at Module._compile (internal/modules/cjs/loader.js:694:28)
at Module._compile (/Users/myfolder/workspace/webapp/node_modules/pirates/lib/index.js:83:24)
at Module._extensions..js (internal/modules/cjs/loader.js:745:10)
at Object.newLoader [as .js] (/Users/myfolder/workspace/webapp/node_modules/pirates/lib/index.js:88:7)
at Module.load (internal/modules/cjs/loader.js:626:32)
at tryModuleLoad (internal/modules/cjs/loader.js:566:12)
at Function.Module._load (internal/modules/cjs/loader.js:558:3)
更新:如果我 cd 进入服务器文件夹,我可以成功运行节点服务器。 我的文件夹结构是: myapp/src/server/index.js
这行得通 - 虽然不理想。
cd myapp/src/server cross-env NODE_ENV=生产节点index.js
我没有收到上述错误。我正在使用 webpack 构建应用程序,这让我觉得这与我的 webpack 配置有关。
【问题讨论】:
【参考方案1】:我可以通过添加 babel 的根目录来解决这个问题。 'root' 是 babel 的配置加载选项,它指定当前 babel 项目的概念根文件夹。我的 cwd 是 src。 src/server/index.js 现在看起来像这样。
require('@babel/polyfill');
require('@babel/register')(
ignore: [/\/(build|node_modules)\//],
root:"./server",
presets: ['@babel/preset-env','@babel/preset-react'],
plugins: [
'@babel/plugin-syntax-dynamic-import',
'dynamic-import-node',
]
);
require('./server');
【讨论】:
这对我有帮助,因为我意识到我正在尝试从根文件夹外部导入文件,即:import something from '../../somefile.js'
babel 不会触及以上是关于SyntaxError: 尝试使用 @babel/register 时意外的令牌导出的主要内容,如果未能解决你的问题,请参考以下文章
Babel 编译错误 SyntaxError: Unexpected token when using spread operator
Babel编译错误SyntaxError:使用spread运算符时出现意外的标记
babel无法识别jsx语法... SyntaxError:意外的令牌(25:1)[重复]
Gulp、Vue、Webpack、Babel 和 Uncaught SyntaxError:意外的令牌导入
SyntaxError: Unexpected token import Webpack 2 Babel 6 Reactjs