3

Date在后端定义了一个名为 ISO 8601 字符串的自定义标量类型。

在前端“GraphQL 代码生成器”(https://www.graphql-code-generator.com/)用于从模式生成打字稿类型。

codegen.yml看起来像这样:

overwrite: true
schema: 'http://mybackenurl/graphql'
documents: 'src/**/*.graphql'
generates:
    src/generated/graphql.ts:
        config:
            exposeQueryKeys: true
            exposeFetcher: true
            fetcher: '../GraphQLFetcher#fetcher'
            scalars: 
                Date: Date
        plugins:
            - 'typescript'
            - 'typescript-operations'
            - 'typescript-react-query'

这给出了在 graphql 模式中具有自定义标量类型的所有字段Date对应于Date生成的打字稿类型中的打字稿类型的类型。但是在运行时它仍然是一个string. 如果Date: Date去掉了配置中标量下的部分,则对应的类型为Any.

猜测是我们需要指定某种映射器,它将我们从后端获得的 ISO 8601 字符串转换为 typescript Date,但我不明白这是怎么做到的。

4

1 回答 1

2

Codegen 不做任何转换,你可以把Date: number它放在你生成的文件中,它会很高兴地打印出来。它实际上只是一种为您的 API 自动生成 Typescript 类型的方法。

您正在寻找的是不同的,您基本上需要来自您的 graphql 客户端的“中间件”:

  1. 有权访问架构。因此,这意味着您需要能够轻松地将整个架构与您的前端应用程序一起交付,而大多数开发人员并不是专门针对私有 API 的。
  2. 可以解析所述模式以将 JSON 响应中的字段匹配到标量,然后将它们解释为您想要的任何本机类型(例如Date

对于 Apollo 客户端,您可以使用https://github.com/eturino/apollo-link-scalars。对于 urql,我找到了https://github.com/clentfort/urql-custom-scalars-exchange

于 2021-10-03T02:33:56.837 回答