如何使用 gatsby-plugin-image 插件通过 GraphQL 查询图像

How to Query Images via GraphQL with the gatsby-plugin-image plugin

您好,我将 Prismic 用作 Headless CMS,并想在 gatsby-plugin-images 插件中查询图像。不幸的是,我没有收到任何错误消息或其他任何信息,它只是无法正常工作。

class Index extends Component {
  render() {
    const {
      data: { homepage },
    } = this.props
    const image = getImage(homepage.data.gesichter.localFile)
    return (
      <Layout>
        <IndexWrapper id={website.skipNavId} style={{ paddingTop: '2rem', paddingBottom: '2rem' }}>
          <Hero>
            <HeroInner>
              <H1>{homepage.data.title.text}</H1>
              <GatsbyImage image={image} alt={homepage.data.gesichter.alt} />
            </HeroInner>
          </Hero>
        </IndexWrapper>
      </Layout>
    )
  }
}

export default Index

Index.propTypes = {
  data: PropTypes.shape({
    homepage: PropTypes.shape({
      data: PropTypes.shape({
        title: PropTypes.shape({
          text: PropTypes.string.isRequired,
        }),
        content: PropTypes.shape({
          html: PropTypes.string.isRequired,
        }),
        gesichter: PropTypes.shape({
          alt: PropTypes.string.isRequired,
          localFile: PropTypes.shape({
            childImageSharp: PropTypes.shape({
              gatsbyImageData: PropTypes.element.isRequired,
            }),
          }),
        }),
      }),
    }),
  }).isRequired,
}

export const pageQuery = graphql`
  query IndexQuery {
    homepage: prismicHomepage {
      data {
        title {
          text
        }
        content {
          html
        }
        gesichter {
          alt
          localFile {
            childImageSharp {
              gatsbyImageData(
                width: 200
                placeholder: BLURRED
               
                layout: FULL_WIDTH
              )
            }
          }
        }
      }
    }
  }
`

我认为道具类型有问题 gatsbyImageData: PropTypes.element.isRequired, 但我没有进一步了解。

有人知道该怎么做吗?

您的 localFile 字段可能是 null。根据您的 PropTypes,localFile 字段不是必需的,这可能是您没有看到警告或错误的原因。

您能否确认 gatsby-source-prismic 配置为本地下载文件?

您可以通过将其包含在您网站的 gatsby-config.js 文件中来执行此操作:

// In your gatsby-config.js
plugins: [
  {
    resolve: 'gatsby-source-prismic',
    options: {
      // Along with your other options...

      // Set a function to determine if images are downloaded locally and made
      // available for gatsby-transformer-sharp for use with gatsby-image.
      // The document node, field key (i.e. API ID), and field value are
      // provided to the function, as seen below. This allows you to use
      // different logic for each field if necessary.
      // This defaults to always return false.
      shouldDownloadImage: ({ node, key, value }) => {
        // Return true to download the image or false to skip.
        return true
      },
    },
  },
]

在大多数情况下,该选项可能如下所示:

plugins: [
  {
    resolve: 'gatsby-source-prismic',
    options: {
      // Along with your other options...
      shouldDownloadImage: () => true,
    },
  },
]

使用 gatsby develop 重新启动您的 Gatsby 开发服务器后,您应该会在 localFile 字段中看到您的图像正在下载并可用。