成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

被 Next.js 的環境變量給坑了一把...

開發 前端
在 Next.js 中,執行 next dev? 命令時需要確保 NODE_ENV? 為 development?。執行 next start?和 next build? 命令時需要確保 NODE_ENV? 為 production。

最近在使用 Next.js 時遇到了一個問題,最后原因竟是 .env 取值問題,為這個問題花費了數小時的時間,希望看到這篇文章的朋友,如果遇到類似問題,不要重蹈覆轍吧。

起初報錯內容如下所示:

圖片圖片

一開始關注點在下面這行:

Generating static pages (0/10)  [==  ] ? TypeError: Cannot read properties of null (reading 'useContext')

看到這個報錯以為只是 useContext Hook 的使用問題,看了代碼后也沒看出什么問題并且在同事的電腦試過了沒有此問題,這就很難辦了!

懷疑是否是版本問題,升級到最新的 V14.0.1 還是沒能解決。之后在 Next.js Issue 下搜索相關關鍵詞,確實找到了類似的提問,例如:?issues#57277、?issues#52478、?discussions#43577,截止目前沒看到好的解決辦法,還在討論這個問題。

之后,注意到控制臺有以下警告信息。

圖片圖片

根據提示看了下詳細內容,注意到了下面標注的這句話,大概意思是如果未設置標準的 NODE_ENV 環境變量可能會導致依賴關系出現意外行為。

圖片圖片

這個 “意外行為” 就很難講了,說不定真和上面的報錯有關系,在執行 next build 時,打印了 NODE_ENV 環境變量發現被修改為了 development。在代碼層面我是沒有設置的,后來查了下本機的 ~/.zshrc 文件,發現這里設置了 NODE_ENV 環境變量為 development,才導致的 next build 時環境變量取值繼承了本機設置的環境變量。

嘗試修改命令為 NODE_ENV=production next build,結果成功了。但這種神奇的構建問題,對用戶體驗是真的不夠好。

下面對 Next.js 環境變量的一些規則做個總結

在 Next.js 中,執行 next dev 命令時需要確保 NODE_ENV 為 development。執行 next start和 next build 命令時需要確保 NODE_ENV 為 production。

按照 Next.js 官網給的建議,在我們的代碼倉庫最好有三個文件:

  • .env(所有環境)
  • .env.development(開發環境)
  • .env.production(生產環境)

注意環境變量的加載順序,Next.js 按以下順序查找環境變量,一旦找到變量就停止。

  • process.env
  • .env.$(NODE_ENV).local
  • .env.local
  • .env.$(NODE_ENV)
  • .env

關于環境變量更多內容參考 Next.js 文檔 ?https://nextjs.org/docs/app/building-your-application/configuring/environment-variables

責任編輯:武曉燕 來源: 編程界
相關推薦

2025-03-19 08:06:31

2024-09-18 00:00:01

ChatGPTOpenAI工具型

2022-10-13 18:54:57

JavaScriptQwikReact

2024-12-13 08:37:32

2021-06-09 08:21:14

Webpack環境變量前端

2022-02-22 20:48:48

RemixNext.js框架

2024-01-04 14:16:05

騰訊紅黑樹Socket

2021-12-27 08:31:42

Next.js SSRSSG

2025-02-03 00:00:35

2024-04-18 08:00:23

openInula?React響應式 API

2019-10-30 05:51:07

物聯網設備物聯網安全物聯網

2024-11-25 07:39:48

2024-09-20 15:37:02

2024-05-09 09:01:03

2025-01-17 09:29:42

2025-03-06 00:00:00

2020-12-14 11:40:27

Next.js SSRReact

2024-12-16 08:40:51

2024-03-29 08:32:01

Node.jsNext.js組件

2024-04-28 10:56:34

Next.jsWeb應用搜索引擎優化
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 91在线导航 | 在线免费观看黄色av | 久久精品亚洲精品 | 久久久久亚洲精品 | 国产成人精品久久二区二区91 | 国产欧美一区二区三区在线看 | 欧美一区二区 | 久草网址 | 久久精品国产久精国产 | 国内自拍视频在线观看 | 欧美日韩国产三级 | 久久久久久综合 | 色女人天堂 | 91极品尤物在线播放国产 | 久久久成人精品 | 麻豆久久久久 | 西西裸体做爰视频 | 国产精品1区2区3区 国产在线观看一区 | 91九色视频| 日韩激情免费 | 成人在线免费av | 欧产日产国产精品视频 | 亚洲导航深夜福利涩涩屋 | 久久精品国产亚洲a | 亚洲国产精品激情在线观看 | 亚洲精品二区 | 日韩午夜网站 | 麻豆国产一区二区三区四区 | 日韩精品免费 | 91久久精品一区二区三区 | 亚洲精品久久久久久久久久久 | 男人天堂av网站 | 国产成人综合网 | 日韩精品中文字幕一区二区三区 | 久久久久亚洲 | 成人久草 | 欧美精品成人 | 精产嫩模国品一二三区 | 午夜av在线| 成人精品一区二区三区中文字幕 | 国产日产久久高清欧美一区 |