javascript - Next JS firebase TypeError : firebase_app__WEBPACK_IMPORTED_MODULE_1__. 存储不是函数

标签 javascript firebase next.js firebase-storage

import * as firebase from 'firebase/app';
import 'firebase/firestore';
import 'firebase/storage';

已经在此处添加了 firestore 导入,以便解决大多数其他人的问题

const clienteCredentials = {
    apiKey: process.env.NEXT_PUBLIC_FIREBASE_API_KEY,
authDomain: process.env.NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN,
projectId: process.env.NEXT_PUBLIC_FIREBASE_PROJECT_ID,
storageBucket: process.env.NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET,
messagingSenderId: process.env.NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID,
appId: process.env.NEXT_PUBLIC_FIREBASE_APP_ID,
measurementId: process.env.NEXT_PUBLIC_FIREBASE_MEASUREMENT_ID
};

export default function initFirebase() {
  if (!firebase.apps.length){
      firebase.initializeApp(clienteCredentials);
  }
}

这里不断出现错误:

    const projectStorage = firebase.storage();
    const projectFirestore = firebase.firestore();


export { projectFirestore, projectStorage };

最佳答案

如果您使用的是 Firebase V9.0.0+,那么您可以使用 compat 版本来继续使用现有代码(V8 namespace 语法):

import firebase from "firebase/compat/app"
import "firebase/compat/storage"
import "firebase/comapt/firestore"

我推荐upgrading to new Modular Syntax它有一定的好处并且支持tree-shaking。新的语法如下所示:

import { initializeApp } from "firebase/app" // no compat
import { getFirestore } from "firebase/firestore"
import { getStorage } from "firebase/storage"

const app = initializeApp({...config})

const firestore = getFirestore(app)
const storage = getStorage(app)

请查看documentation其中包含旧语法和新语法的示例。

关于javascript - Next JS firebase TypeError : firebase_app__WEBPACK_IMPORTED_MODULE_1__. 存储不是函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69340203/

相关文章:

reactjs - useState set 方法没有立即反射(reflect)变化(Stackoverflow 中建议的解决方案不起作用)

javascript - 确定嵌套 HTML 列表内相邻的 <li>

javascript - 在 JavaScript 警报中使用 PHP 从文件中收集的数据

java - 如何在 firebase 中创建条件

java - 每次应用启动时 FirebaseRecyclerAdapter 都会崩溃

javascript - Firebase - 未捕获( promise )TypeError : Cannot read property

javascript - 选择文件后更改上传占位符

javascript - SPServices 的 TypeScript 定义文件

reactjs - 我的组件在不应该的情况下改变了它的 props

next.js - 如何将 blurha.sh 与新的 Next.JS 图像组件一起使用