我正在使用gatsby CMS创建站点,但是现在遇到了一个我不知道如何解决的问题。
我有从gatsby-node中的markdown文件创建的项目页面。它可以正常工作,创建带有适当标记的页面,等等。现在的问题是,我创建了两个项目页面,它们都具有被称为相同的图像-但它们位于不同的文件夹中:
在projects/foo.md
---
templateKey: project-page
headerImage: /img/projects/foo/Header.jpg
---
然后在projects/bar.md
---
templateKey: project-page
headerImage: /img/projects/bar/Header.jpg
---
然后在我调用的模板中
<div className="hero"
style={{ backgroundImage: `url(${data.headerImage.publicURL})` }}
>
它非常适合foo
项目。但是对于bar
来说,它仍然显示与foo
中相同的图像,因为两者都是style='background-image: url("/static/Header-920eee5baf94303a7a172f4ccef3b60b.jpg");'
。我不知道发生了什么。
如果有帮助,我的gatsby-node.js
的内容为:
const _ = require('lodash')
const path = require('path')
const { createFilePath } = require('gatsby-source-filesystem')
const { fmImagesToRelative } = require('gatsby-remark-relative-images')
exports.createPages = ({ actions, graphql }) => {
const { createPage } = actions
return graphql(`
{
allMarkdownRemark(limit: 1000) {
edges {
node {
id
fields {
slug
}
frontmatter {
templateKey
headerImage {
publicURL
}
}
}
}
}
}
`).then(result => {
if (result.errors) {
result.errors.forEach(e => console.error(e.toString()))
return Promise.reject(result.errors)
}
const projects = result.data.allMarkdownRemark.edges
projects.forEach(edge => {
const id = edge.node.id
createPage({
path: edge.node.fields.slug,
tags: edge.node.frontmatter.tags,
component: path.resolve(
`src/templates/${String(edge.node.frontmatter.templateKey)}.jsx`
),
// additional data can be passed via context
context: {
data: edge.node.frontmatter
},
})
})
})
}
exports.onCreateNode = ({ node, actions, getNode }) => {
const { createNodeField } = actions
fmImagesToRelative(node) // convert image paths for gatsby images
if (node.internal.type === `MarkdownRemark`) {
const value = createFilePath({ node, getNode })
createNodeField({
name: `slug`,
node,
value,
})
}
}