gpt4 book ai didi

javascript - Gatsby 第二个布局模板

转载 作者:行者123 更新时间:2023-11-30 14:24:56 29 4
gpt4 key购买 nike

我有一个自己创建的模板,它用于显示单个产品的页面 (blog-post.js)。现在我需要一种带有自己模板(category-post.js)的新型页面,它将显示特定类别中的所有产品。我不知道会有多少类别,所以我需要它们是动态的(以编程方式创建)。

要做到这一点,我想我应该使用 onCreatePage API。在我添加 onCreatePage 函数之前,代码运行良好。

我是通过关注 these docs 做到的来自 www.gatsbyjs.org,关于选择页面布局。我希望我至少在这方面走在正确的轨道上。

gatsby-node.js,问题好像出在这里:

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: 200) {
edges {
node {
id
categories
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.onCreatePage = async ({ page, boundActionCreators }) => {
const { createPage } = boundActionCreators

return new Promise((resolve, reject) => {
if (page.path.match(/^\/category-post/)) {
// I have created `category-post.js` in the `/layouts/` directory
page.layout = 'category-post'

createPage(page)
}

resolve()
})
}

终端enter image description here

我还可以指定我正在使用 Contentful CMS,这是否可以通过那里的一些 API 以某种方式完成?

有人做过类似的事情并想帮忙吗?

最佳答案

要动态创建页面,您仍然需要使用 createPages API。人们想念的一件事是,您可以拥有任意多的 GraphQL 查询。onCreatePage 在这种情况下是不必要的,因为您正在寻找未创建的页面

exports.createPages = ({ graphql, boundActionCreators }) => {
const { createPage } = boundActionCreators

return new Promise((resolve, reject) => {
const blogPost = path.resolve('./src/templates/blog-post.js')
const categoryPost = path.resolve('./src/templates/category-post.js')
resolve(
graphql(
`
{
allContentfulBlog(limit: 200) {
edges {
node {
id
categories
slug
}
}
}
allContentfulCategory(limit: 200) {
edges {
node {
id
categories
slug
}
}
}
}
`
).then(result => {
if (result.errors) {
console.log(result.errors)
reject(result.errors)
}
result.data.allContentfulCategory.edges.forEach(edge => {
createPage({
path: `categories/${edge.node.slug}`,
component: categoryPost,
context: {
slug: edge.node.slug,
},
})
})
result.data.allContentfulBlog.edges.forEach(edge => {
createPage({
path: edge.node.slug,
component: blogPost,
context: {
slug: edge.node.slug,
},
})
})
return
})
)
})
}

关于javascript - Gatsby 第二个布局模板,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52095495/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com