1

这可能是一个基本问题,但仍然无法确定为什么我只能在此示例 graphql 查询中看到一个文件的概念:

query {
  file {
    childImageSharp {
      id
      fluid {
        src
      }
    }
  }
}

但我可以看到我列出的所有图片:

query MyQuery {
  allFile {
    nodes {
      childImageSharp {
        id
      }
    }
  }
}

别人可以我做错了吗?我很确定这是一个配置问题,但不确定可能是什么问题。谢谢!

4

2 回答 2

1

我一开始是按照题名回答的。再次阅读您的问题后,我意识到我根本没有回答您的问题。

您的问题与 无关childImageSharp,它与您正在使用的查询有关。

  • file查询将只要求一个结果。
  • 默认情况下,allFile查询将询问所有结果(您可以在其上添加过滤器)。

我建议多学习一些有关 graphql 的知识,https ://www.howtographql.com/很受欢迎。

这是我的原始答案

您可以尝试这样的事情来查看所有分辨率:

query {
    file(relativePath: { eq: "logo.jpg" }) {
      childImageSharp {
        fluid(maxWidth: 800) {
          srcSet
        }
      }
    }
  }

你会得到类似的东西:

{
  "data": {
    "file": {
      "childImageSharp": {
        "fluid": {
          "srcSet": "/static/320cb30c50318c089773e0770b96b2a2/d278e/logo.jpg 200w,\n/static/320cb30c50318c089773e0770b96b2a2/8539d/logo.jpg 400w,\n/static/320cb30c50318c089773e0770b96b2a2/bc3a8/logo.jpg 800w,\n/static/320cb30c50318c089773e0770b96b2a2/81ef8/logo.jpg 1200w,\n/static/320cb30c50318c089773e0770b96b2a2/989b1/logo.jpg 1600w,\n/static/320cb30c50318c089773e0770b96b2a2/96775/logo.jpg 9094w"
        }
      }
    }
  }
}

但在 gatsby 中,我们通常使用 gatsby-image,因此请务必在查询中使用正确的 Fragments:https ://www.gatsbyjs.org/packages/gatsby-image/#fluid-queries

于 2019-12-08T18:02:11.520 回答
0

一般回答 - 您问题中的两个查询都按预期工作;没有配置问题。

第一个查询总是只返回一个结果。你可以提供参数来控制你得到的结果。您可以在 Gatsby 站点的 GraphQL 架构中查看有关可用参数的更多信息。

于 2019-12-08T19:19:12.940 回答