【发布时间】:2020-07-15 11:35:19
【问题描述】:
我正在挖掘graphql,所以我遵循了一个教程,我坚持在这一部分。
Home.js
function Home() {
const {
loading,
data: { getPosts: posts } // <===## Here ##
} = useQuery(FETCH_POSTS_QUERY);
return (
<div>
{loading ? (
<h1>Loading posts..</h1>
) : (
posts &&
posts.map((post) => (
<p>
{post.content}
</p>
))
)}
</div>
);
}
const FETCH_POSTS_QUERY = gql`
{
getPosts {
id
content
}
}
`;
export default Home;
解析器
Query: {
async getPosts() {
try {
const posts = await Post.find().sort({ createdAt: -1 });
return posts;
} catch (err) {
throw new Error(err);
}
}
},
完整代码:https://github.com/hidjou/classsed-graphql-mern-apollo/tree/react10
在上面的例子中运行良好,它使用data: { getPosts: posts } 来解构返回的数据。但是在我的代码中,我遵循了它,但出现了错误
TypeError:无法读取未定义的属性“getPosts”
相反,如果我像下面这样编码,
function Home() {
const {
loading,
data // <===## Here ##
} = useQuery(FETCH_POSTS_QUERY);
if(loading) return <h1>Loading...</h1>
const { getPosts: posts } = data // <===## Here ##
return (
<div>
{loading ? (
<h1>Loading posts..</h1>
) : (
posts &&
posts.map((post) => (
<p>
{post.content}
</p>
))
)}
</div>
);
}
它运作良好。似乎我的代码在加载之前尝试引用data。但我不知道为什么会这样。代码几乎相同。不同的东西是1. my code is on nextjs,2. my code is on apollo-server-express。其他几乎相同,我的解析器使用async/await,并将返回posts。我错过了什么吗?
我的解析器如下所示。
Query: {
async getPosts(_, { pageNum, searchQuery }) {
try {
const perPage = 5
const posts =
await Post
.find(searchQuery ? { $or: search } : {})
.sort('-_id')
.limit(perPage)
.skip((pageNum - 1) * perPage)
return posts
} catch (err) {
throw new Error(err)
}
},
【问题讨论】:
标签: graphql react-apollo apollo-client