我尝试使用 React 进行 firebase 身份验证,但它显示错误,"Attempted import error: 'firebase/app' does not contain a default export (imported as 'firebase')"
。如果我使用import * as firebase from "firebase/app"
然后停止显示错误的代码。
import firebase from 'firebase/app';
import 'firebase/auth';
const app = firebase.initializeApp({
apiKey: process.env.REACT_APP_FIREBASE_API_KEY,
authDomain: process.env.REACT_APP_FIREBASE_AUTH_DOMAIN,
projectId: process.env.REACT_APP_FIREBASE_PROJECT_ID,
storageBucket: process.env.REACT_APP_FIREBASE_STORAGE_BUCKET,
messagingSenderId: process.env.REACT_APP_FIREBASE_MESSAGING_SENDER_ID,
appId: process.env.REACT_APP_FIREBASE_APP_ID
});
export const auth = app.auth();
export default app;
Firebase 模块化 SDK (v9
)正式发布并npm install firebase
现在安装这个而不是旧的namespaced
版本 (v8
)。如果您正在使用v9
然后将您的代码重构为:
import { initializeApp } from 'firebase/app';
import { getAuth } from 'firebase/auth';
import { getDatabase } from "firebase/database";
const app = initializeApp({...config});
export const auth = getAuth()
const database = getDatabase();
export { auth, database }
我建议遵循文档并继续使用新的模块化 SDK。如果您有现有的并且想要使用现有的命名空间版本,那么您可以将导入替换为兼容库,如下所示:
import firebase from 'firebase/compat/app';
import 'firebase/compat/auth';
firebase.initializeApp({...config})
const auth = firebase.auth()
const database = firebase.database()
查看这个视频来自 Firebase v9 入门。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)