首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

用TS+GraphQL查询SpaceX火箭发射数据

TypeScript 通过为变量添加静态类型来扩展 JavaScript,从而减少了错误并提高了代码的可读性。...Apollo 查询graphql-tag 用于构建我们的查询文档, graphql 是一个对等依赖项,它提供了 GraphQL 实现的细节。...: true 编写 GraphQL 查询并生成类型 GraphQL 最主要的好处是它利用声明性数据进行提取。...由于这将通过用户交互动态生成,所以需要用到 GraphQL 变量。我们还可以在 playground 上测试带变量查询。...在查询名的后面,你可以通过使用前缀为$及类型去指定变量,然后在查询体中,你可以使用该变量。对于我们的查询,通过传递 $id 变量来设置启动的id,该变量类型为String!。 ?

3K20
您找到你想要的搜索结果了吗?
是的
没有找到

GraphQL学习第二篇 -GraphQL类型查询方式

GraphQL类型 GraphQL类型系统分为标量类型(Scalar Types,标量类型)和其他高级数据类型。...标量类型即可以表示最细粒度数据结构的数据类型,可以和 JavaScript 的原始类型对应。 1. GraphQL 规范目前规定支持的标量类型有: (1). Int -有符号 32 位整数。...ID-ID 标量类型表示一个唯一标识符,通常用以重新获取对象或者作为缓存中的键。 2. GraphQL 其他高级数据类型包括: (1)....Object - 对象,用于描述层级或者树形数据结构,对于树形数据结构来说,叶子字段的类型都是标量数据类型,几乎所有 GraphQL 类型都是对象类型。...GraphQL查询方式 GraphQL 规范支持两种操作: 1. query-仅获取数据(fetch)的只读请求。 2. mutation-获取数据后还有写操作的请求。

85020

怎样使用 apollo-link-state 管理本地数据

此外,GraphQL 有能力将对多个数据源的请求集成在单次查询中,在此我们将充分利用这个特性。 . 以上是 Apollo Client 的数据流架构图。...Resolvers 在使用 Apollo Client 管理应用状态后,Apollo cache 成为了应用的单一数据源,包括了本地和远端的数据。那么我们应当如何查询和更新缓存中的数据呢?...如果你以前在服务器端使用过 graphql-tools,那么你会发现两者的 resolver 的类型签名是一样的。 ....如果你没见过以上这段类型签名,不要紧张,只需记住重要的两点:query 或者 mutation 的变量通过 args 参数传递给 resolver;Apollo cache 会作为 context 参数的一部分传递给...以上代码使用 @client 指令查询 Apollo cache。 在我们 最新的文档页中,可以找到更多的例子,以及一些将 apollo-link-state 集成在应用中的小贴士。

2.3K100

GraphQL最突出的架构优势是什么?

作者 | Khalil Stemmler 策划 | 田晓旭 在服务器上使用 GraphQL 代替 REST 是有很多好处的,使用 Apollo Client 取代自己编写的数据获取逻辑也有很多优势。...Apollo 发布了带有 apollo-link-state 的 Apollo Client 后,React 开发人员就能用更少的代码满足所有这三个需求了。...Apollo-link-state(现已直接放入 Apollo Client 2 和 3 中)让开发人员可以编写几乎同时解决远程状态和本地状态的查询。远程状态(位于服务器上)感觉比之前近多了。...locally } } }`; 在主要用于获取远程资源的查询中,我们可以使用 @client 指令来引用要基于一个客户端模式从本地缓存中获取的属性。...数据图从客户端延伸到服务器,并为现代 Web 应用程序中获取数据和更改状态时面临的最常见基础架构问题提供了答案 为了通过 GraphQL 与后端服务通信,Apollo Client 公开了几种客户端方法

2.1K20

在 redux 应用中使用 GraphQL

您需要编写自定义代码来调用服务器接口,解释数据,对其进行规范化并将其插入到存储中 - 同时跟踪各种错误和加载状态。 在本教程中,您将学习如何通过 Apollo Client 来获取和管理数据。...快速的启动一个服务端环境 启动一个 redux 脚手架 增加一个 GraphQL 客户端 (Apollo Client) 使用 GraphQL 获取数据 获取更多的数据 接下来要做的 1....增加一个 GraphQL 客户端(Apollo 客户端) 安装 apollo-client, react-apollo, 和 graphql-tag。...$ npm install apollo-client react-apollo graphql-tag --save 打开 Redux 应用的入口文件 src/containers/AppContainer.js...不过我准备在后续的教程中介绍这些内容,您可以阅读 Sashko 的 文章 或者 Apollo Client 文档来更好的理解 GraphQL 的原理 (比如,当我们把 Provider 替换成 ApolloProvider

1.9K10

GraphQL+Koa2实现服务端API结合Apollo+Vue

它弥补了 RESTful API(字段冗余,扩展性差、无法聚合 api、无法定义数据 类型、网络请求次数多)等不足 注意:GraphQL 是 api 的查询语言,而不是数据库。...,错误的数据类型可能会导致网站出错 尤其是在业务多变的场景中,很难在保证工程质量的同时快速满足业务需求 GraphQL 的优点 吸收了 RESTful API 的特性 所见即所得 各种不同的前端框架和平台可以指定自己需要的字段...但 GraphQL 提供了强类型的 schema 机制,从而天然确保了参数类型的合法性 二、GraphQl类型系统 2.1 GraphQl类型 可以将GraphQL类型系统分为标量类型(ScalarTypes...修改 删除 五、Vue中使用GraphQl 5.1 使用graphQl简单查询 安装 找到Vue中集成GraphQl的文档 https://github.com/vuejs/apollo https...将它与vue-apollographql一起安装: npm install vue-apollo graphql apollo-boost --save 在src/main.js中引入apollo-boost

5.1K42

你还在用 REST API 吗?

我们传递查询并得到响应。除此之外,它还允许我们将不同的实体组合到单个查询中。 GraphQL 的优势 检索精确的数据,无任何多余数据。...GraphQL 的劣势 对于简单的应用程序来说,设置类型查询等可能有点 复杂,因为使用 REST 可以很容易地完成。 它使用的是 单个端点,而不是遵循 HTTP 规范进行缓存。...自动缓存 REST 能自动生效缓存,而 GraphQL 则没有自动缓存系统,但是可以借助 Apollo Client、Relay 等客户端实现缓存。...错误处理 REST 中的错误处理比 GraphQL 简单得多,GraphQL 通常会给我们一个 200 OK 的状态码,即使已经出现错误了。...但是,当使用 Apollo Client、Relay 等客户端时,它也能很容易处理错误。 结 论 与 REST 相比, GraphQL 当然更具优势,但它可能并不总是最佳实践。

1.5K10

【译】Graphql, gRPC和端对端类型检验

由于GraphQL查询可以一次请求多种资源,因此可以减少网络请求的次数。 未来可以很方便地增加服务端接口。...使用apollo-client和react-apollo简化了前端代码对缓存和数据的管理。 灵活的查询方式方便我们在未来构建移动端以及内部应用。...为了保证GraphQL server和前端之间的类型安全,我们使用Apollo CLI的代码生成器:使用命令行来生成我们所有GraphQL查询类型: React示例 在我们的应用中需要用到三种查询:...{ deleteTodo(input: $input) { success } } 基于这些GraphQL查询和我们的服务端GraphQL schema,我们可以给这些查询生成typescript...此外,由于实现了端对端的类型检验,很难出现数据的错误使用或是引入向前不兼容的变更。如果我们需要引入向前不兼容的变更,也很容易在发生变更之前决定我们系统中的哪些部分是需要进行修改的。

3.1K20

为 Vue 配置 GraphQL API

使用 Vue Apollo Vue Apollo[2] 是一个三方库,可以让你在 Vue 的应用中使用 GraphQL,使用起来也很轻松,在上述 hello-world 目录下,也就是 package.json...同级的目录下,打开命令窗口执行: vue add apollo 这个命令会自动安装 npm 包:graphql graphql-tag @apollo/client。...Django 里面的 graphql查询语句,因为需要传入参数,这里外层做了一下封装,不要问为啥这样写,这是 apollo 规定好了的,我们只需要比葫芦画瓢,如下: query categoryByName...到这里,我们已经实现了前端通过 GraphQL API 获取后端数据的过程。 其实,Vue Apollo 还有很多功能,比如上传文件。...说明可能遇到了 django cors 错误,按照上面的方法解决即可。

1.2K20

GraphQL到底怎么使?看看智联前端团队技术沉淀

}, updateTime: '2020-04-11' } } 预期数据会返回在 data 中,当有错误时,会出现 errors 字段并按照规范规定的格式展示错误。...其他定义 当然,在使用 GraphQL 的过程中,还可以: 使用 Variables(变量)复用同一段 Document 来动态传参。...几乎是 Apollo GraphQL: Apollo 提供的实现和 GraphQL 生态,内容丰富,不止一套引擎,还提供了纯客户端使用(不局限JavaScript)多种工具。...Apollo Apollo 提供了完整的 GraphQL Node.js 服务框架,但是为了更直观的感受可执行 Schema 的创建过程,使用 Apollo 提供的 graphql-tools 进行可执行...强类型(字段校验):由于 JS 语言特性,强类型只能称为字段强类型校验(包括入参类型和返回结果),当数据源返回了比 Schema 多或少的字段时,并不会引发错误,而就算采用了 TypeScript 由于没有运行时校验

2.3K20
领券