盖茨比-覆盖图片

时间:2018-12-28 15:04:03

标签: javascript graphql gatsby

我正在使用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,
    })
  }
}

0 个答案:

没有答案