babel 版本原因運行報錯,解決辦法

来源:https://www.cnblogs.com/schuan/archive/2020/05/12/12873479.html
-Advertisement-
Play Games

學習 babel 時,遇到的問題,使用舊版本 babel 命名規則安裝後運行報錯,初步查找到原因是因為 babel 各個preset和plugin新舊不同版本之間存在相容問題,提示使用 npx babel-upgrade 可以自動升級,但是我升級失敗了,提示解析錯誤,後來看到了這篇文章,問題得以解決 ...


學習 babel 時,遇到的問題,使用舊版本 babel 命名規則安裝後運行報錯,初步查找到原因是因為 babel 各個preset和plugin新舊不同版本之間存在相容問題,提示使用 npx babel-upgrade 可以自動升級,但是我升級失敗了,提示解析錯誤,後來看到了這篇文章,問題得以解決。現在被我原封不動的給扒了過來當筆記(複製,主要還是懶  [手動狗頭])

babel 升級到7.X採坑總結

最近工作比較忙,有一段時間沒有寫前端玩了。今天試著搭一個項目,發現各種坑,以前用起來非常好的配置文件各種報錯。排查後發現原來babel升級了一個大版本,已經到7.X了,這裡我總結一下升級過程中踩到的坑。


Error: Cannot find module '@babel/core'
babel-loader@8 requires Babel 7.x (the package '@babel/core'). If you'd like to use Babel 6.x ('babel-core'), you should install 'babel-loader@7'.
    at Function.Module._resolveFilename (module.js:547:15)
    at Function.Module._load (module.js:474:25)
    at Module.require (module.js:596:17)
    at require (internal/module.js:11:18)
    ....

沒找到@babel/core,需要把babel-core卸載掉,從新安裝@babel/core
npm un babel-core
npm i -D @babel/core


ERROR in ./src/index.jsx
Module build failed (from ./node_modules/babel-loader/lib/index.js):
Error: Plugin/Preset files are not allowed to export objects, only functions.
...

babel-preset-*卸載,重新安裝@babel/preset-*,並且修改 .babelrc中的 presets

比如我的

npm:
- babel-preset-env
+ @babel/preset-env
- babel-preset-react
+ @babel/preset-react
- babel-preset-stage-0

.babelrc:
- "presets": ["react", "env", "stage-0", "mobx"]
+ "presets": ["@babel/preset-react", "@babel/preset-env", "mobx"]

除了上述的preset,我還用了babel-preset-mobx
但是沒找到 @babel/preset-mobx,從babel-preset-mobx git提交日誌上看,作者已經支持了最新的babel。在之後的測試中,發現mobx的功能也能正常使用。
另外,stage-*已棄用


ERROR in ./src/index.jsx
Module build failed (from ./node_modules/babel-loader/lib/index.js):
TypeError: this.setDynamic is not a function
    at PluginPass.pre
    ...

這次是插件了,一樣把babel-plugin-*卸載,重新安裝@babel/plugin-*
然後修改.babelrc文件
具體的包名可以在 npm倉庫 里找

最終文件

.babelrc:

{
    "presets": ["@babel/preset-env", "@babel/preset-react", "mobx"],
    "plugins": [
        "@babel/plugin-proposal-object-rest-spread",
        "@babel/plugin-transform-runtime"
    ]
}

package.json:

"devDependencies": {
    "@babel/core": "^7.1.0",
    "@babel/plugin-proposal-object-rest-spread": "^7.0.0",
    "@babel/plugin-transform-runtime": "^7.1.0",
    "@babel/preset-env": "^7.1.0",
    "@babel/preset-react": "^7.0.0",
    "babel-loader": "^8.0.2"
    "babel-preset-mobx": "^2.0.0",
    ...
  },
  "dependencies": {
    "@babel/runtime": "^7.0.0",
    ...
  }

總結

這次升級,功能上有什麼變化我就不在這裡寫了,大家可以自行搜索

總的來說,babel捨棄了以前的 babel-*-* 的命名方式,改成了@babel/*-*
修改依賴和.babelrc文件後就能正常啟動項目了。
webpack不用修改(除非你是webpack 3.X webpack 4.X

上面的只是我遇到的問題,如果還有其他問題,可以參考資料 升級指南 Upgrade to Babel 7

 

                本作品系作者:Shurlormes原創 , 採用《署名-非商業性使用-禁止演繹 4.0 國際》許可協議

 

轉自:https://segmentfault.com/a/1190000016458913   作者:Shurlormes

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • http://www.redis.cn/commands/expire.html http://www.redis.cn/topics/lru cache.html 記憶體管理 當 Redis 作為緩存使用時(此時緩存僅作為熱點數據提高服務的訪問性能),需要考慮記憶體的限制,以及如何隨著業務的增長,僅保 ...
  • Cassandra是雲原生和微服務化場景中最好的NoSQL資料庫。我信了~ 1. Cassandra是什麼 高可用性和可擴展的分散式資料庫 Apache Cassandra™是一個開源分散式數據,可提供當今最苛刻的應用程式所需的高可用性、高性能和線性可伸縮性。它提供了跨雲服務提供商、數據中心和地理位 ...
  • 理解和掌握Redis的持久機制,對於Redis的日常開發和運維都有很大幫助,也是在大廠面試經常被問到的知識點。 ...
  • Netflix(Nasdaq NFLX),也就是網飛公司,成立於1997年,是一家線上影片[租賃]提供商,主要提供Netflix超大數量的[DVD]並免費遞送,總部位於美國加利福尼亞州洛斯蓋圖。1999年開始訂閱服務。2009年,該公司可提供多達10萬部DVD電影,並有1千萬的訂戶。2007年2月2 ...
  • 文本的一些屬性 android:id="@+id/editText" 給文本的id重命名 android:layout_width="wrap_content" 必要的長寬 android:layout_height="wrap_content" android:ems="10" 本文本框一行的最大 ...
  • 本項目目的是在移動端的 Native App 中以庫的形式集成已經寫好的 Unity 工程,利用 Unity 游戲引擎便捷的開發手段進行跨平臺開發。 ...
  • 更多的文章請看-2020iOS面試大全 持續更新! 分類 擴展 代理(Delegate) 通知(NSNotification) KVO (Key-value observing) KVC (Key-value coding) 屬性關鍵字 一、分類 1.分類的作用? 聲明私有方法,分解體積大的類文件, ...
  • 新聞 1. "喪心病狂or形勢所迫?談談Android奇葩的“鏈式啟動”" 1. "傳聞稱Android TV將更名為Google TV" 1. "谷歌官宣Android 11 Beta發佈會:6月3日見" 教程 1. "協程 Flow 最佳實踐 | 基於 Android 開發者峰會應用" 1. " ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...