使用@ nestjs / graphql使用@ResolveProperty和@Resolvers创建嵌套查询

时间:2019-05-06 03:48:33

标签: javascript typescript graphql graphql-js nestjs

参考NestJS储存库here中的type-graphql示例存储库,我想知道如何在查询中再创建两层。

当前已设置为查询配方,我能够添加另一个@ObjectType类

@ObjectType()
export class Author {
  @Field(type => Int)
  id: number;

  @Field({ nullable: true })
  firstName?: string;

  @Field({ nullable: true })
  lastName?: string;
}

并在配方解析器中使用以下方法创建了@ResolveProperty:


  @ResolveProperty('author', type => Author)
  async getAuthor(@Parent() recipe) {
    console.log('Resolver auth in recipe', recipe);
   // This will be a database call, just mocking data for now.
    return Promise.resolve({ id: 1, firstName: 'john', lastName: 'smith' });
  }

使用GraphQL查询,一切正常(我还为Author创建了一个单独的解析器,但这不是我的基本查询,所以我不包含它)

{
  recipe(id: "1") {
    title,
    author {
      firstName
    }
  }
}

此查询返回

{
  "data": {
    "recipe": {
      "title": "1",
      "author": {
        "firstName": "john"
      }
    }
  }
}

应当如此。我现在的问题是如何添加另一个级别?我试图创建一个“发布者” ObjectType

@ObjectType()
export class Publisher {
  @Field(type => Int)
  id: number;
}

但是在Author和Recipe解析器中创建解析器或添加ResolveProperty并没有使其工作。我应该将解析器代码放在哪里,以便在GraphQL解析器解析Author对象时,它也可以解析关联的发布者信息。

我的目标是获取它,以便查询诸如:

{
  recipe(id: "1") {
    title,
    author {
      firstName,
      publisher: {
         id
      }
    }
  }
}

会返回

{
  "data": {
    "recipe": {
      "title": "1",
      "author": {
        "firstName": "jay",
        "publisher": {
           id: 4        
        }
      }
    }
  }
}

不确定我是否在考虑这个错误,但这似乎是一个关键想法,我想进一步扩展它!谢谢。

1 个答案:

答案 0 :(得分:0)

基本上,您将只定义一个AuthorResolver来描述如何使用Author。在此AuthorResolver中,您将拥有一个@ResolveProperty装饰的方法来解析您的publisher属性,如下所示:

// author.resolver.ts
@ResolveProperty('publisher', type => PublisherObjectType, {})
async resolvePublisher(@Parent() parent: AuthorEntity) {
   return await parent.getPublisher(); // this method would return your Publisher!
}

请注意,您需要创建自己的PublisherObjectType(带有相应的装饰器)并使其可用。.