Graphql查询不会返回gatsby图像的图像,但可以在graphiQL中使用

时间:2020-02-25 10:30:56

标签: graphql gatsby gatsby-image

我正在建立具有多个gatsby-source-filesystem实例的博客。

我正在尝试在页面上使用gatsby-image,但它只会返回: TypeError: Cannot read property 'fixed' of undefined

我要查询的图像位于src / images

spirits.js

import React from "react"
import { graphql } from "gatsby"
import Img from 'gatsby-image'

import Layout from "../components/layout"
import SEO from "../components/seo"
import Paper from '../components/paper'


const SpiritsPage = ({data}) => (
        <Layout>
            <SEO title="Spirits" />
            <Paper>
                <h1>Spirits</h1>
                <p>This section is still under construction.</p>
                <Img fixed={data.allImageSharp.edges.node.fixed} alt />
            </Paper>
        </Layout>
    )

export const query = graphql`
    query {
        allImageSharp(filter: {fluid: {originalName: {eq: "australia.png"}}}) {
            edges {
                node {
                    fixed {
                        ...GatsbyImageSharpFixed
                    }
                }
            }
        }
    }

`

export default SpiritsPage

gatsby-config.js

{
            resolve: `gatsby-source-filesystem`,
            options: {
                name: `distilleries`,
                path: `${__dirname}/content/distilleries`,
            },
        },
        {
            resolve: `gatsby-source-filesystem`,
            options: {
                name: `images`,
                path: `${__dirname}/src/images`,
            },
        },
        {
            resolve: `gatsby-source-filesystem`,
            options: {
                name: `posts`,
                path: `${__dirname}/content/posts`
            },
        },
        `gatsby-transformer-sharp`,
        `gatsby-plugin-sharp`,

1 个答案:

答案 0 :(得分:0)

data.alImageSharp.edges是一个数组,因此不能执行data.allImageSharp.edges.node。相反,您需要做的是从edges数组中获取所需的项目,然后对其进行node.fixed。类似以下内容将起作用:data.allImageSharp.edges[0].node.fixed

信用– goto1