首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >@babel/polyfill (Babel 7 beta)导致SyntaxError

@babel/polyfill (Babel 7 beta)导致SyntaxError
EN

Stack Overflow用户
提问于 2017-12-01 13:03:27
回答 1查看 2.7K关注 0票数 0

请不要将此标记为任何Babel 7! 6 问题的副本,因为这是专门关于Babel 的问题。

我正在试用新的Babel 7测试版(@babel/polyfill@7.0.0-beta.32等)。我在使用@babel/polyfill时遇到了麻烦。

摘要

  • 当我和Webpack一起做这个项目的时候,一切都很好。
  • 当我试图从命令行运行它时,我会得到一个SyntaxError。

我可能只是忘了一些简单的东西,但我不能为我的生活弄明白什么。有什么问题吗?

系统规范

  • macOS高级塞拉利昂开发人员Beta 5
  • 节点8.9.1
  • 国家预防机制5.5.1

文件

.babelrc.js

代码语言:javascript
复制
module.exports = {
  presets: [
    ['@babel/preset-env', { targets: { node: 6 } }],
    ['@babel/preset-stage-3'],
    ['@babel/preset-flow']
  ]
}

src/index.js

代码语言:javascript
复制
require('@babel/polyfill')
module.exports = require('./main')

src/main.js

代码语言:javascript
复制
import 'dotenv-safe/config'

命令行

代码语言:javascript
复制
$ node --trace-warnings ./src/index.js

错误消息

代码语言:javascript
复制
import 'dotenv-safe/config'
^^^^^^

SyntaxError: Unexpected token import
    at createScript (vm.js:80:10)
    at Object.runInThisContext (vm.js:139:10)
    at Module._compile (module.js:599:28)
    at Object.Module._extensions..js (module.js:646:10)
    at Module.load (module.js:554:32)
    at tryModuleLoad (module.js:497:12)
    at Function.Module._load (module.js:489:3)
    at Module.require (module.js:579:17)
    at require (internal/module.js:11:18)
    at Object.<anonymous> (/Users/deniz/Code/my-project/src/index.js:3:18)

package.json

代码语言:javascript
复制
{
  "name": "foobar",
  "private": true,
  "version": "1.0.0",
  "description": "lol",
  "main": "./dist/bundle.js",
  "module": "./src/main.js",
  "scripts": {
    "clean": "rimraf dist",
    "build": "webpack",
    "watch": "webpack -w",
    "flow": "flow",
    "flow-typed": "flow-typed",
    "dev": "node --trace-warnings ./src/index.js",
    "start": "node ./dist/bundle.js"
  },
  "devDependencies": {
    "@babel/cli": "^7.0.0-beta.32",
    "@babel/core": "^7.0.0-beta.32",
    "@babel/preset-env": "^7.0.0-beta.32",
    "@babel/preset-flow": "^7.0.0-beta.32",
    "@babel/preset-stage-3": "^7.0.0-beta.32",
    "babel-eslint": "^8.0.2",
    "babel-loader": "^8.0.0-beta.0",
    "dotenv-safe": "^4.0.4",
    "eslint": "^4.12.0",
    "eslint-config-prettier": "^2.9.0",
    "eslint-plugin-flowtype": "^2.39.1",
    "eslint-plugin-prettier": "^2.3.1",
    "flow-bin": "^0.59.0",
    "flow-typed": "^2.2.3",
    "prettier": "^1.8.2",
    "rimraf": "^2.6.2",
    "webpack": "^3.9.1"
  },
  "dependencies": {
    "@babel/polyfill": "^7.0.0-beta.32",
    "node-schedule": "^1.2.5"
  }
}

webpack.config.js

代码语言:javascript
复制
const path = require('path')

module.exports = {
  target: 'node',
  entry: ['./src/index.js'],
  output: {
    path: path.resolve(__dirname, 'dist'),
    filename: 'bundle.js'
  },
  module: {
    rules: [
      {
        test: /\.js$/,
        include: [path.resolve(__dirname, 'src')],
        loader: 'babel-loader'
      }
    ]
  },
  externals: [
    {
      mariasql: true,
      msnodesql: true,
      msnodesqlv8: true,
      mysql: true,
      mysql2: true,
      oracle: true,
      oracledb: true,
      'pg-query-stream': true,
      pg: true,
      sqlite3: true,
      'strong-oracle': true,
      tds: true
    }
  ],
  devtool: 'source-map'
}
EN

回答 1

Stack Overflow用户

发布于 2017-12-01 13:25:44

尝试将入口点entry键更改为:entry: ['babel-polyfill', './src/index.js']。根据文档,多填充必须位于入口点的顶部。https://babeljs.io/docs/usage/polyfill

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47594033

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档