内容丰富的CMS数据层没有到达我的Gatsby/React博客



我在Gatsby数据层使用local.md文件,但现在我需要Contentful CMS集成。

const Promise = require('bluebird')
const path = require('path')
exports.createPages = ({ graphql, boundActionCreators }) => {
const { createPage } = boundActionCreators
return new Promise((resolve, reject) => {
const blogPost = path.resolve('./src/templates/blog-post.js')
resolve(
graphql(
`
{
allContentfulBlog(limit: 500) {
edges {
node {
id
slug
}
}
}
}
`
).then(result => {
if (result.errors) {
console.log(result.errors)
reject(result.errors)
}
result.data.allContentfulBlog.edges.forEach(edge => {
createPage({
path: edge.node.slug,
component: blogPost,
context: {
slug: edge.node.slug,
},
})
})
return
})
)
})
}
exports.onCreateNode = ({ node, boundActionCreators, getNode }) => {
const { createNodeField } = boundActionCreators
}

这是我的gatsby-node.js文件。

终端给出:

TypeError:无法读取未定义的属性"allContentfulBlog"。

在Contentful.com上,内容类型的名称是Blog。

我附上了一张终端的屏幕截图在这里

有人暗示吗?

它看起来像

TypeError:无法读取未定义的属性"allContentfulBlog"。

是的结果

无法查询类型"ContentfulBlog"上的字段"slug">

您是否可以分享您的内容模型?我不知道你有没有看过盖茨比的开场白。它附带了一个内容模型,所以你也可以看看那里。:(

相关内容

  • 没有找到相关文章

最新更新