Heroku SyntaxError:意外的令牌“导出”

时间:2020-11-05 15:05:29

标签: javascript node.js heroku webpack

我正在开发node.js / express网络应用程序。当我在本地主机环境中运行时。一切都像魅力。但是当我部署到Heroku时,出现以下错误:

2020-11-04T19:16:15.678297+00:00 app[web.1]: SyntaxError: Unexpected token 'export'
2020-11-04T19:16:15.678298+00:00 app[web.1]: at wrapSafe (internal/modules/cjs/loader.js:979:16)
2020-11-04T19:16:15.678299+00:00 app[web.1]: at Module._compile (internal/modules/cjs/loader.js:1027:27)
2020-11-04T19:16:15.678299+00:00 app[web.1]: at Object.Module._extensions..js (internal/modules/cjs/loader.js:1092:10)
2020-11-04T19:16:15.678299+00:00 app[web.1]: at Module.load (internal/modules/cjs/loader.js:928:32)
2020-11-04T19:16:15.678300+00:00 app[web.1]: at Function.Module._load (internal/modules/cjs/loader.js:769:14)
2020-11-04T19:16:15.678300+00:00 app[web.1]: at Module.require (internal/modules/cjs/loader.js:952:19)
2020-11-04T19:16:15.678301+00:00 app[web.1]: at require (internal/modules/cjs/helpers.js:88:18)
2020-11-04T19:16:15.678301+00:00 app[web.1]: at Object.<anonymous> (/app/twilio/handler.js:3:22)
2020-11-04T19:16:15.678301+00:00 app[web.1]: at Module._compile (internal/modules/cjs/loader.js:1063:30)
2020-11-04T19:16:15.678302+00:00 app[web.1]: at Object.Module._extensions..js (internal/modules/cjs/loader.js:1092:10)
2020-11-04T19:16:15.682211+00:00 app[web.1]: error: Forever detected script exited with code: 1
2020-11-04T19:16:15.886448+00:00 app[web.1]: error: Script restart attempt #83
2020-11-04T19:16:16.263688+00:00 app[web.1]: /app/server/utilities.js:3
2020-11-04T19:16:16.263698+00:00 app[web.1]: export function ExpressErrorModel(title, req, error_object, user) {
2020-11-04T19:16:16.263699+00:00 app[web.1]: ^^^^^^

它所引用的文件具有以下模块:

const CryptoJS = require("crypto-js");

export function ExpressErrorModel(title, req, error_object, user) {
  let error = {
    error_title: title,
    error_request: req.headers,
    error_object: error_object,
    error_user: user,
    timestamp: new Date(Date.now())
  };
  return error;
}

我正在使用以下引擎部署到Heroku:

  "engines": {
    "node": "14.x",
    "npm": "6.x"
  },

你们中有人遇到过这个问题吗?在我的本地主机上运行正常,但在Heroku部署上失败。

1 个答案:

答案 0 :(得分:1)

您正在混合使用CommonJS模块语法(require和ES6模块语法(export)。

一个模块只能使用其中之一。

您的Node.js实例正在使用CJS加载程序,因此将模块更改为以CJS样式导出:

module.exports = { ExpressErrorModel };