0

所以我使用 gatsby-source-airtable 从我的空气表中提取图像。

在我的 gastby-config 中,我将附件列映射为 filenode:

mapping: {'image':fileNode},

在 GraphiQL gatsby 图像插件似乎正在工作这个查询:

{
airtable(table: {
    eq: "table-1"
}, data: {
    slug: {
        eq: "test-1"
    }
}) {
    data {
        image {
            localFiles {
                childImageSharp {
                    fluid(maxWidth: 400) {
                        src
                    }
                }
            }
        }
    }
}

}

提供此响应:

{
"data": {
    "airtable": {
        "data": {
            "image": {
                "localFiles": [{
                    "childImageSharp": {
                        "fluid": {
                            "src": "/static/08baa0d1735184a4d0dd141d90f564d4-28158c2eb0b0b748efeabc0ec551c623-7eb65.jpg"
                        }
                    }
                }]
            }
        }
    }
}

}

然后转到该 src 生成图像并出现在浏览器中。

但是,当我尝试将其与 gatsby-image 一起使用时:

<Img fluid={post.data.image.localFiles.childImageSharp.fluid} />

    export const query = graphql query PostQuery {
    airtable(table: {
        eq: "table-1"
    }, data: {
        slug: {
            eq: "test-1"
        }
    }) {
        data {
            image {
                localFiles {
                    childImageSharp {
                        fluid(maxWidth: 400) { ...GatsbyImageSharpFluid
                        }
                    }
                }
            }
        }
    }
}

我收到此错误:

WebpackError:TypeError:无法读取未定义的属性“流体”

我在做什么错?任何助手将不胜感激

4

2 回答 2

0

查询该localFiles字段image将为您提供一个数组。在 GraphiQL 中测试查询:

请注意,您必须将...GatsbyImageSharpFluid片段(GraphiQL 不支持)替换为另一个字段,例如src

airtable(table: {
  eq: "table-1"
}, data: {
  slug: {
    eq: "test-1"
  }
}) {
  data {
    image {
      localFiles {
        childImageSharp {
          fluid(maxWidth: 400) {
            src
          }
        }
      }
    }
  }
}

你应该得到类似的东西:

{
  "data": {
    "airtable": {
      "data": {
        "image": {
          "localFiles": [
            {
              "childImageSharp": {
                "fluid": {
                  "src": "/static/8a6a13a2664ef8330843b7855ad2c5e2/d278e/o.jpg"
                }
              }
            }
          ]
        }
      }
    }
  }
}

如您所见,localFiles是一个数组,因此在您的组件中您应该编写:

<Img fluid={post.data.image.localFiles[0].childImageSharp.fluid} />
于 2019-06-26T14:33:35.857 回答
0

您没有将数据传递给您的 gatsby 图像组件之一,因此它会引发错误。尝试在运行时单击您的页面gatsby develop以查看发生这种情况的位置。此外,任何错误报告或日志都会有所帮助。

于 2018-11-06T04:47:25.533 回答