0

鉴于此架构:

const typeDefs = gql`type Asset {
  id: ID!
  name: String!
  ScanProfiles: [ScanProfile]
}

type ScanProfile {
  id: ID!
  name: String!
  Assets: [Asset]
}

type Query {
  Asset(id: ID!): Asset
  ScanProfile(id: ID!): Asset
}`;

// Some generic resolvers...
const resolvers = {
  Asset: (root, args, context) => context.get('asset', args),
  ScanProfile: (root, args, context) => context.get('scanProfile, args),
  Query: {
    Asset: (root, args, context) => context.get('asset', args),
    ScanProfile: (root, args, context) => context.get('scanProfile', args)
  }
};

const schema = makeExecutableSchema({typeDefs, resolvers

const joinResolvers = {
  Asset: {
    ScanProfiles: (root, args, context) => { 
      console.log(root.ScanProfiles);
      return root.ScanProfiles.map(id => context.get('scanProfile', {id});
    }
  },
  ScanProfiles: {
    Assets: (root, args, context) => {
      console.log(root.id);
      return context.filter('asset', {ScanProfiles: ({ScanProfiles}) => ScanProfiles.includes(root.id)}); 
    }
  }
};

addResolveFunctionsToSchema({ schema, resolvers: joinResolvers });

我希望context.get给定的 id 返回这些形状:

// Asset
{
  id: '1234',
  name: 'abcd',
  ScanProfiles: ['5678', '5679']
}
//ScanProfile
{
  id: '5678',
  name: 'efgh'
}

控制台正在返回[null]Asset.ScanProfiles

根解析器将字段作为字符串数组返回,但是当根随后传递给joinResolvers这些文件时,这些文件为空。我假设是因为它们与定义的 typeDef 不匹配。

要解决此问题,我必须单独调用以重新获取父级,然后为子级提取存储的值。

我是否错误地定义了我的类型?我的解析器结构错了吗?

4

1 回答 1

0

问题在于定义类型。

当父级解析时,它期望子级是一个 Object 数组,但交付的是一个字符串数组。因此,类型验证根据此处结果 1 中定义的“冒泡”返回一个空数组。

github上有一个公开讨论允许联合标量类型

于 2019-02-27T14:51:12.263 回答