gpt4 book ai didi

node.js - Gatsby 3 – `gatsby build` 在 'Building static HTML for pages' 上失败,错误为 'WebpackError: ReferenceError: ... is not defined' (firebase/app)

转载 作者:行者123 更新时间:2023-12-04 17:19:41 28 4
gpt4 key购买 nike

当运行 gatsby build 时,该过程在 Gatsby v3 上失败。

一些上下文......Firebase 模块包含在自定义 Hook 中(显示代码如下)。

在 gatsby-node 中有一个自定义的 webpack 配置函数,它使用 webpack 外部特性来推迟在构建阶段加载此模块,直到在用户浏览器中运行时加载(显示此代码也在下面)。

我已经将所有相关包更新到当前版本并且没有相关的依赖错误或过时的包。

如果需要任何其他上下文,请告诉我,更多信息和示例如下。

gatsby build 产生以下错误:

success Building HTML renderer - 17.646s
failed Building static HTML for pages - 0.562s

ERROR #95313

Building static HTML failed

See our docs page for more info on this error: https://gatsby.dev/debug-html


> 1 | module.exports = __WEBPACK_EXTERNAL_MODULE_firebase_app__;
| ^


WebpackError: ReferenceError: __WEBPACK_EXTERNAL_MODULE_firebase_app__ is not defined

- app":1
/external "firebase/app":1:1

- bootstrap:19
/webpack/bootstrap:19:1

- useFirebase.js:7
/src/hooks/useFirebase.js:7:18

- bootstrap:19
/webpack/bootstrap:19:1

- bootstrap:19
/webpack/bootstrap:19:1

- bootstrap:19
/webpack/bootstrap:19:1

- sync-requires.js:7
/.cache/_this_is_virtual_fs_path_/$virtual/sync-requires.js:7:49

- bootstrap:19
/webpack/bootstrap:19:1

- static-entry.js:11
/.cache/static-entry.js:11:22

- utils.js:283
/[@gatsbyjs]/reach-router/lib/utils.js:283:1

- plugin.js:5
/[@savvywombat]/tailwindcss-grid-areas/src/plugin.js:5:1

- utils.js:163
/[@gatsbyjs]/reach-router/lib/utils.js:163:1

我修复了之前的一个错误,即自从从 gatsby 2 更新到 gatsby 3 后自定义 webpack 外部函数被错误调用。

配置 webpack 外部的 gatsby-node 中的代码可能直接相关,目前看起来像这样:

exports.onCreateWebpackConfig = ({ stage, actions, getConfig }) => {
if (stage === 'build-html' || stage === 'develop-html') {
actions.setWebpackConfig({
externals: getConfig().externals.concat(({ context, request }, callback) => {
const regex = /^@?firebase(\/(.+))?/
if (regex.test(request)) {
return callback(`umd ${request}`)
}
callback()
})
})
}
}

因为这似乎也与 firebase 模块直接相关,下面是来 self 的自定义 useFirebase Hook 的导入行(这之前取自另一个堆栈溢出线程或 github 问题,并在 gatsby 中工作2.

...
import firebase from 'firebase/app'
import 'firebase/auth'
import 'firebase/firestore'
import 'firebase/storage'
import 'firebase/messaging'

let app
let messaging

const config = {
...
}

// don't initialize untill you're in the browser - required to work with Gatsby
if (typeof window !== 'undefined') {
app = app || firebase.initializeApp(config)

package.json 中的相关模块版本和解析(我想这就是全部):

  "dependencies": {
"gatsby": "^3.2.1",
"@firebase/app": "^0.6.18",
"@firebase/auth": "^0.16.4",
"@firebase/firestore": "^2.2.2",
"@firebase/messaging": "^0.7.7",
"@firebase/storage": "^0.4.6",
...
}
"resolutions": {
"graphql": "^15.4.0",
"graphql-compose": "^7.25.0",
"webpack": "^5.24.2"
}

如果有人对此问题有任何经验或想法,我将不胜感激,谢谢!


更新我尝试用以下替代代码替换 onCreateWebpackConfig:

exports.onCreateWebpackConfig = ({ stage, loaders, actions }) => {
if (stage === 'build-html') {
actions.setWebpackConfig({
module: {
rules: [
{
test: /^@?firebase(\/(.+))?/,
use: loaders.null()
}
]
}
})
}
}

它消除了旧错误并产生了以下错误:

failed Building static HTML for pages - 0.737s

ERROR #95313

Building static HTML failed

See our docs page for more info on this error: https://gatsby.dev/debug-html


85 | ]);
86 |
> 87 | proxyRequestMethods(Index, '_index', IDBIndex, [
| ^
88 | 'get',
89 | 'getKey',
90 | 'getAll',


WebpackError: ReferenceError: IDBIndex is not defined

- idb.mjs:87
/[idb]/lib/idb.mjs:87:1

- bootstrap:19
/webpack/bootstrap:19:1

- bootstrap:19
/webpack/bootstrap:19:1

- bootstrap:19
/webpack/bootstrap:19:1

- bootstrap:19
/webpack/bootstrap:19:1

- bootstrap:19
/webpack/bootstrap:19:1

- bootstrap:19
/webpack/bootstrap:19:1

- bootstrap:19
/webpack/bootstrap:19:1

- sync-requires.js:7
/.cache/_this_is_virtual_fs_path_/$virtual/sync-requires.js:7:49

- bootstrap:19
/webpack/bootstrap:19:1

但是,我不确定这是否比上次尝试更进一步...

最佳答案

看来您在上次尝试中走得更远,因为 Firebase 实现失败的不是主要方法,而是实现本身。

几周前我遇到了同样的问题,我关注了这个 GitHub thread ,所提供的解决方案对我的情况有所帮助。在您的应用中,由于它是自定义实现,您可能需要对其进行一些调整。

思路依赖于延迟加载Firebase模块导入(动态导入)。在使用 Firebase 的最高层组件中,像这样导入它:

import('firebase').then(firebase => {
firebase.initializeApp({ /* firebaseConfig goes here */});
firebase.firestore().collection('items').doc('yJd1Fs5Ampttq6QKBoYF').get()
.then(doc => {
// do stuff with Firestore data
});
});

我建议阅读以下内容:https://kyleshevlin.com/firebase-and-gatsby-together-at-last ,有什么可以给点建议的。

关于node.js - Gatsby 3 – `gatsby build` 在 'Building static HTML for pages' 上失败,错误为 'WebpackError: ReferenceError: ... is not defined' (firebase/app),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66934602/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com