7

我有一个 GraphQL 服务器,其运行模式大致如下:

type Card {
  id: String!
  name: String
}

type Query {
  card(name: String!): Card
  cards(power: String): [Card]
}

请注意,我对单张卡进行了查询,但也对多张卡进行了查询。当我使用 GraphIQl UI 并进行类似“查询 {cards { name }}”的查询时,我得到了一系列卡片,正如预期的那样。

但是,我有一个 RelayContainer 正在执行相同的查询,但返回的道具只是第一个结果,而不是结果数组。

class MyApp extends React.Component {
  render() {
    return (
      <div>
        <h1> Hello world!</h1>
        <CardList cards={this.props.cards} />
      </div>
    );
  }
}

export default Relay.createContainer(MyApp, {
  fragments: {
    card: () => Relay.QL`
      fragment on Card {
        name
      }
    `,
    cards: () => Relay.QL`
      fragment on Card {
        ${CardList.getFragment('cards')}
      }
    `
  },
});

并且 CardList 组件是使用 Container 设置的,如下所示:

class CardList extends React.Component {
  render() {
    return <div>{this.props.cards}</div> // UNEXPECTED - this.props.cards is the first card, not an array for me to .map over
  }
}

export default Relay.createContainer(CardList, {
  fragments: {
    cards: () => Relay.QL`
      fragment on Card {
        name
      }
    `,
  },
});

有人有什么建议吗?这是我深入研究 GraphQL 和 Relay 的第二天,所以据我所知,我可能犯了一个非常基本的错误。

4

1 回答 1

12

您可能希望在查询片段@relay(plural: true)上有一个指令。在 Relay repo中的 Star Wars 示例cards中有一个复数字段的示例。

但是,如果您关心分页,您可能需要一个连接而不是复数字段。连接在 Relay 文档中描述并在graphql-relay-js中实现。

于 2015-09-10T17:45:55.237 回答