1. ホーム
  2. javascript

[解決済み] Babel 7 へのアップグレード:null のプロパティ 'bindings' を読み取ることができません。

2022-05-13 06:44:58

質問

にアップグレードしたところ バベル 7 (6 から) アップグレードしました。

npm remove babel-cli
npm install --save-dev @babel/cli @babel/core @babel/preset-env

ここで、私の .babelrc ファイルです。

{ "presets": ["env"] }

それから、実行した。

babel js/src --out-dir js/dist

という結果になる。

TypeError: Cannot read property 'bindings' of null
    at Scope.moveBindingTo (/xyz/node_modules/@babel/traverse/lib/scope/index.js:867:13)
    at BlockScoping.updateScopeInfo (/xyz/node_modules/babel-plugin-transform-es2015-block-scoping/lib/index.js:364:17)
    at BlockScoping.run (/xyz/node_modules/babel-plugin-transform-es2015-block-scoping/lib/index.js:330:12)
    at PluginPass.BlockStatementSwitchStatementProgram (/xyz/node_modules/babel-plugin-transform-es2015-block-scoping/lib/index.js:70:24)
    at newFn (/xyz/node_modules/@babel/traverse/lib/visitors.js:193:21)
    at NodePath._call (/xyz/node_modules/@babel/traverse/lib/path/context.js:53:20)
    at NodePath.call (/xyz/node_modules/@babel/traverse/lib/path/context.js:40:17)
    at NodePath.visit (/xyz/node_modules/@babel/traverse/lib/path/context.js:88:12)
    at TraversalContext.visitQueue (/xyz/node_modules/@babel/traverse/lib/context.js:118:16)
    at TraversalContext.visitSingle (/xyz/node_modules/@babel/traverse/lib/context.js:90:19)

何がいけなかったのでしょうか?

どうすればいいのでしょうか?

あなたの .babelrc ファイルを変更します。

{ "presets": ["env"] } 

から

{ "presets": ["@babel/preset-env"] }

(そして、まだインストールしていない場合はそのパッケージをインストールしてください)。

あなたの .babelrc では、まだパッケージ babel-preset-env (これは 6.x 用です) を参照している場合、あなたは @babel/preset-env を参照します (これは 7.x 用です)。

https://github.com/babel/babel/issues/6186#issuecomment-366556833

注意 において、この変更を行う必要があります。 webpack.config.js にある場合も同様に変更してください。

プリセットを変更するサンプルのwebpack configセクションはこちらです。

use: {
  loader: 'babel-loader',
  options: {
    // Here you should change 'env' to '@babel/preset-env'
    presets: ['@babel/preset-env'],
  },
},