javascript - 在 reactjs 中使用 firebase 数据库时出现 Firebase JS SDK 警告
问题描述
我正在尝试为我的项目使用 firebase 数据库,但我无法正确导入和使用该模块。我遵循了官方文档的建议。
这是我使用它的代码。
import React from "react";
import firebase from "firebase";
import ProjectItemCards from "./components/project-item-cards";
const ProjectContext = React.createContext();
class ProjectProvider extends React.Component {
constructor() {
super();
this.state = {
social: {},
projects: [],
featuredProjects: [],
loading: true,
};
}
componentDidMount() {
var ref = firebase.database().ref("projects");
ref.on("value", (snapshot) => {
const projects = snapshot.val();
console.log(projects);
const featuredProjects = projects
.map((project) => (project.featured === true ? project : null))
.slice(0, 4);
this.setState({
projects,
featuredProjects,
loading: false,
});
});
}
getProjectElements(projects) {
const projectElementList = projects.map((project, index) => {
return (
<ProjectItemCards key={index} project={project}></ProjectItemCards>
);
});
return projectElementList;
}
render() {
return (
<ProjectContext.Provider
value={{ ...this.state, getProjectElements: this.getProjectElements }}
>
{this.props.children}
</ProjectContext.Provider>
);
}
}
export { ProjectProvider, ProjectContext };
我已经按如下方式初始化了firebase
import React from "react";
import ReactDOM from "react-dom";
import App from "./App";
import "bootstrap";
import "./sass/main.scss";
import * as firebase from "firebase/app";
import "firebase/analytics";
var firebaseConfig = {
apiKey: process.env.REACT_APP_API_KEY,
authDomain: "",
databaseURL: "",
projectId: "",
storageBucket: "",
messagingSenderId: "",
appId: "1:841600272388:web:12314d1260dded0601cd51",
measurementId: "G-55E4QT6C4F",
};
// Initialize Firebase
firebase.initializeApp(firebaseConfig);
firebase.analytics();
ReactDOM.render(<App />, document.getElementById("root"));
我已经从上面的代码中删除了所有敏感信息 另请注意,我正在按要求获取数据,并且一切正常。我只想摆脱这个警告
解决方案
初始化代码应在实用程序文件中使用,如下所示:
import * as firebase from 'firebase/app'
import 'firebase/firestore'
import 'firebase/storage'
const firebaseConfig = {
apiKey: process.env.REACT_APP_FIREBASE_API_KEY,
authDomain: process.env.REACT_APP_FIREBASE_AUTH_DOMAIN,
databaseURL: process.env.REACT_APP_FIREBASE_DATABASE_URL,
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
}
firebase.initializeApp(firebaseConfig)
export const db = firebase.firestore()
export const storage = firebase.storage()
export default firebase
您想要导出您正在使用的各个 Firebase 功能。在你的情况下,我会假设 firebase.firestore
那么您的导入应该如下所示:
import {db} from '../utils/firebase'
推荐阅读
- swift - 使用 swift 使 DispatchQueue 异步崩溃
- javascript - 如何根据值更改@html 对象属性
- python - 如何将串行数据从数字倾角仪转换为 Python 中的可读格式?
- jmeter - 在另一个测试计划中引用在 Jmeter 中有一组采样器的线程组?
- ms-access - 访问来自不同行的合并文本
- javascript - 从文件中读取 Int 值,全部在一行中
- python - 从键列表中获取字典的值
- android - Android 资源链接失败:id/null
- amazon-web-services - Amazon Athena 跨账户访问
- javascript - 克隆javascript对象省略一个属性