อัปเกรดเป็น Babel 7: ไม่สามารถอ่านคุณสมบัติ 'การผูก' ของ null


118

ฉันเพิ่งอัปเกรดเป็นBabel 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)

ฉันทำอะไรผิด?

คำตอบ:


307

ใน.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 ตัวอย่างที่คุณควรเปลี่ยนค่าที่ตั้งไว้:

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

8
โปรดทราบว่าคุณควรทำการเปลี่ยนแปลงนี้webpack.config.jsหากมีเช่นกัน
ฮ็อค
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.