【发布时间】:2019-02-03 17:27:43
【问题描述】:
我正在构建一个 React 表单,该表单将包含几个下拉框,其中填充来自 MongoDB 的数据。我是 React 的新手,也是 MongoDB 的初学者。
我一开始只是尝试创建一个带有一个下拉菜单的基本页面。一旦我做对了,我就可以继续添加其他下拉菜单。
我只需将所有代码塞入一个文件即可成功地将数据放入下拉列表中。现在,我正在尝试通过将部分正确拆分为单独的文件来开始重构代码。这就是我遇到问题的地方。
我已将我的 MongoDB 数据提取(使用 Mongo Stitch)拆分为一个单独的“服务”文件。而且我仍在通过那个新的服务文件获取数据。但是,当我尝试将该服务文件数据拉入我的主 (App.js) 页面时,我收到“无法读取未定义的属性‘数据’”错误。所以,很明显,我试图将数据拉入我的 App.js 文件的方式是错误的。任何人都可以提供任何专家见解,我将不胜感激!
这是我的 App.js 文件 -
import React, { Component } from "react";
import "./App.css";
import { getProjects } from "./services/svcProjects";
class App extends Component {
state = {
data: {
selProject: ""
},
Projects: []
};
async componentDidMount() {
await this.fetchProjects();
}
async fetchProjects() {
const { data: projects } = await getProjects();
console.log(projects);
this.setState({ projects });
}
render() {
return (
<div className="App">
<h1>Project Log</h1>
<label htmlFor={"selProject"}>{"Project"}</label>
<select name={"selProject"} id={"selProject"} className="form-control">
<option value="" />
{this.state.projects.map(a => (
<option key={a._id} value={a.project}>
{a.project}
</option>
))}
</select>
</div>
);
}
}
export default App;
这是“项目服务”文件。再次请注意,此处的 console.log 语句表明我仍在从 MongoDB 获取数据。我只是没有以正确的方式将数据提取到我的 App.js 文件中。
另外,顺便说一句,我意识到在这个文件中包含我的 Mongo 连接信息是一个巨大的安全漏洞。我稍后会解决这个问题。
import {
Stitch,
RemoteMongoClient,
AnonymousCredential
} from "mongodb-stitch-browser-sdk";
export function getProjects() {
const client = Stitch.initializeDefaultAppClient("------");
const db = client
.getServiceClient(RemoteMongoClient.factory, "-----")
.db("----------");
client.auth
.loginWithCredential(new AnonymousCredential())
.then(() =>
db
.collection("--------")
.find({}, { sort: { Project: 1 } })
.asArray()
)
.then(res => {
console.log("Found docs", res);
console.log("[MongoDB Stitch] Connected to Stitch");
return res;
})
.catch(err => {
console.error(err);
});
}
【问题讨论】:
-
快速查看您的代码,您在 this.setState 中设置了大写 P 的项目
标签: reactjs