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

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

那么剩下的 20% 的本地数据(例如全局标志、设备 API 返回的结果等)应该怎样处理呢? 过去,Apollo 的用户通常会使用一个单独的 Redux/Mobx store 来管理这部分本地的数据。...要实现一个理想的状态管理方案,我们应当对 Redux 取长弃短。此外,GraphQL 有能力将对多个数据源的请求集成在单次查询中,在此我们将充分利用这个特性。 ....尽管不是必需的参数,不过预热缓存是一个很重要的步骤,传入的 default 使得组件不会因为查询不到数据而出错。 . 以上代码的 defaults 代表了 Apollo cache 的初始值。...Resolvers 在使用 Apollo Client 管理应用状态后,Apollo cache 成为了应用的单一数据源,包括了本地和远端的数据。那么我们应当如何查询和更新缓存中的数据呢?...GraphQL 的一个很让人激动的功能是在单个 query 中向多个数据源请求数据。

2.4K100

C# 一分钟浅谈:GraphQL 中的缓存策略

基础概念GraphQL 是一种用于 API 的查询语言,它允许客户端精确地请求所需的数据,从而减少不必要的数据传输。GraphQL 服务器接收客户端发送的查询请求,解析并执行这些查询,最后返回结果。...缓存 是一种提高系统性能的技术,通过存储计算结果并在后续请求中重用这些结果,减少重复计算的时间和资源消耗。在 GraphQL 中,缓存可以应用于多个层面,包括客户端缓存、网络层缓存和服务器端缓存。...当客户端发送一个查询请求时,如果缓存中已经存在相同的数据,则直接从缓存中读取,而不需要再次发送请求。...GraphQL 服务器内部实现,通过缓存查询结果来提高性能。...通常,缓存键应包含查询的所有参数,以确保不同参数的查询不会互相干扰。缓存失效策略:缓存数据需要定期更新或失效,否则可能会导致数据不一致。常见的缓存失效策略包括时间过期、事件驱动和显式清除。

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

    每日前端夜话(0x04):2018年JavaScript状态调查(中)

    GitHub 21k stars ⚛️采用与 Fast 3kB React相同API的替代品。 包括组件和虚拟DOM。...GitHub 10k stars GraphQL是一种可以与任何后端服务相关联的查询语言和执行引擎。 GraphQL 随时间的流行度 ? GraphQL 最受喜欢的方面 ?...功能齐全的GraphQL缓存客户端,适用于UI框架和GraphQL服务器。 Apollo 随时间的流行度 ? Apollo 最受喜欢的方面 ? Apollo 最不受欢迎的方面 ?...GraphQL用户在两年内从5%上升到20%,他们选择的客户端似乎是Apollo。...另外Apollo的最新版本使Redux成为可选项,如果明年的结果看起来非常不同,那就不足为奇了…… 后端框架 后端的JavaScript近年来没有取得任何重大突破。

    1.6K20

    C# 一分钟浅谈:GraphQL 中的缓存策略

    GraphQL 服务器接收客户端发送的查询请求,解析并执行这些查询,最后返回结果。 缓存 是一种提高系统性能的技术,通过存储计算结果并在后续请求中重用这些结果,减少重复计算的时间和资源消耗。...在 GraphQL 中,缓存可以应用于多个层面,包括客户端缓存、网络层缓存和服务器端缓存。 客户端缓存 客户端缓存是最常见的缓存策略之一。...在 GraphQL 中,客户端库(如 Apollo Client)通常会自动管理缓存。当客户端发送一个查询请求时,如果缓存中已经存在相同的数据,则直接从缓存中读取,而不需要再次发送请求。...服务器端缓存可以在 GraphQL 服务器内部实现,通过缓存查询结果来提高性能。...通常,缓存键应包含查询的所有参数,以确保不同参数的查询不会互相干扰。 缓存失效策略:缓存数据需要定期更新或失效,否则可能会导致数据不一致。常见的缓存失效策略包括时间过期、事件驱动和显式清除。

    10110

    GraphQL 基础实践

    什么是 GraphQL GraphQL 是一款由 Facebook 主导开发的数据查询和操作语言, 写过 SQL 查询的同学可以把它想象成是 SQL 查询语言,但 GraphQL 是给客户端查询数据用的...我们以 IMDB 电影信息详情页为例子,看看我们得需要什么样的 API 才能满足 RESTful API 设计的要求。先来看看主页面上都需要什么信息。 ?...也就是说,请求体的结构也确定了最终返回数据的结构。 GraphQL Server 在前面的 REST 举例中,我们请求多个资源有多个 API 端点。...以及 Meteor 团队开发的 Apollo,同时开发了客户端和服务端,同时也支持流行的 Vue 和 React 框架。...id 查询一遍得出结果,最终返回的数据就能符合 Schema 的定义了。

    12.8K20

    React 设计模式 0x6:数据获取

    GraphQL 是用于 API 的查询语言,也是用现有数据来满足这些查询的运行时。...向您的 API 发送 GraphQL 查询,只获取您所需的数据,没有多余的内容。...GraphQL 查询总是返回可预测的结果,使用 GraphQL 的应用程序速度快且稳定,因为它们控制获取的数据,而不是由服务器来控制。...# Memoization Memoization 是一种优化技术,主要用于通过存储昂贵的函数调用结果,并在再次出现相同输入时返回缓存的结果来优化计算机程序。...简单来说,Memoization 是指将结果存储在内存中。Memoization 函数通常更快,因为如果使用相同的参数再次调用函数,则不会重新执行函数,而是从缓存中获取结果。

    1.2K20

    GraphQL是API的未来,但它并非银弹

    与使用 Next.JS 的 BFF 方法相比,在前端获得相同的结果会更复杂。如何使用 GraphQL 实现 Etags?如果没有任何变化,如何使 GraphQL 服务器返回 304 状态码?...你可以向模式添加自定义指令,以获得类似于 OAS 的结果,但你必须得自己维护这样的自定义实现。 你可能会认为,OAS 不能保证 API 的响应符合规范。你说的对。...但是,GraphQL 模式是如何保证的呢? GraphQL 内省是向服务器发送一个特定的 GraphQL 查询以获取关于 GraphQL 模式的信息。...GraphQL 服务器可以自由地使用它期望的任何类型进行响应。如果你发送一个查询,则服务器的响应可以不符合自省响应中的 GraphQL 模式。以 Apollo Federation 为例。...你可以使用其他工具,或者扩展 GraphQL,来获得更好的结果,例如使用 Relay 来持久化查询。要真正地从 GraphQL 文档中获得好处,你要做的不仅仅是向模式中添加描述。

    2K10

    你不知道的 GraphQL

    服务会由外向内依次处理查询块,为每个查询块执行对应的resolver函数,并传递外层调用是的返回结果为第一个参数。...所以我们请求了1次Tweets,结果产生了N次Tweet.Author查询。 为了解决这个问题,我使用了另外一个库:Dataloader[16],它也是Facebook提供的。...为了添加扩展信息,我们需要在graphqlHTTP配置中添加extension函数,它返回一个支持json序列化的对象。...Resolvers拆分 为了能测试resolver和查询引擎,我们不得不把代码拆分到多个独立的文件中。从开发者角度来看这是一个值得的工作 - 它提供了模块化和可维护性。...注意:这篇教程中提到的大多数js库都源自Facebook或Apollo。那么,Apollo到底是哪位?它是来自于Meteor团队的一个项目。这些家伙为GraphQL贡献了很多的高质量代码。顶他们!

    3.3K20

    为什么我使用 GraphQL 而放弃 REST API?

    服务器只需以这种方式实现顶级模式对象。 一个简单的例子 GraphQL 模式定义了可用于在服务器和客户端之间通信的类型。...此模式中的其他变体和查询也是如此:对输入进行类型检查和验证,并且基于查询,GraphQL 服务器知道期望的结果形状。...本质上,所有通信都通过服务器上一个预定义的 URL(通常是/graphql)运行,借助一个简单的POST请求,其中包含序列化为 JSON 有效负载的查询。...有很多流行的开源项目都在使用 GraphQL:这个博客是基于静态站点生成器 Gatsby,它将 GraphQL 查询的结果转换成数据,然后呈现到 HTML 文件中。...相应地,Apollo 提供了多个平台的客户端库,以及在最流行的编程语言(包括 TypeScript 和 Swift)中生成类型定义的代码生成器。

    2.3K30

    设计通过 POST 获取数据的 API 时需要注意的问题

    ❞ SEO 当搜索引擎的爬虫在扫网站时,如果发现需要通过 POST 获取的资源,为了避免造成意外的行为或副作用,通常不会尝试爬取 POST 响应的结果。...GraphQL 虽然 RESTful API 的设计风格优点很多,但也有一些难以避免的缺点。...这时 GraphQL[5] 就应运而生了,这是由 Facebook 提出的开源语言标准,通过 Schema 定义资料,再依靠与 JSON 格式高度类似的查询语句取得查询的结果,它的主要特点是: 強类型...,社区也已经有了庞大的的生态系统支持,例如 Apollo GraphQL[6] 可以与三大框架深度整合,再加上多查询合并的特性,让 GraphQL 与现代框架中组件的概念完美契合。...值得注意的是 GraphQL 发出的全部都是 POST 请求,缓存机制必须仰赖开发者或是框架实现;例如在 Apollo Client 中,开发者必须按照应用场景,调整 fetchPolicy 的设置,避免快取造成的意外结果

    1.6K30

    GraphQL在现代Web应用中的应用与优势

    GraphQL是一种现代的API查询语言,它在现代Web应用中得到了广泛的应用,因为它提供了一种高效、灵活且强大的方式来获取数据GraphQL基础快速应用示例:1....前端设置(使用Apollo Client)接着,我们需要在前端应用中配置Apollo Client,与我们的GraphQL服务器通信:npm install apollo-boost @apollo/client...GraphQL 高级应用1. 分页使用GraphQL Cursor-based分页,以提高性能和用户体验。...GraphQL FederationFederation允许构建由多个服务组成的单一GraphQL API。...缓存优化:客户端可以根据返回的数据结构更容易地进行缓存策略的实施。减少后端复杂性:后端不再需要为了适应不同客户端的需求而创建多个API端点。

    10710

    与我一起学习微服务架构设计模式8—外部API模式

    API由映射到服务的基于图形的模式组成,客户端发出检索多个图形节点的查询。基于查询的API框架通过从一个或多个服务检索数据来执行查询。...基于GraphQL(一种标准)的API Gateway可使用Node.js Express Web 框架和Apollo GraphQL服务器,用js编写。...简单情况下,查询文档包含查询的名称,参数值及要返回结果的对象字段。 把模式连接到数据源 当GraphQL服务器执行查询时,必须从一个或多个数据存储中检索所请求的数据。...GraphQL通过递归调用Query文档中指定的字段解析器函数来执行查询。首先,它执行查询解析器,然后递归调用结果对象层次结构中字段的解析器。...使用批处理和缓存优化负载 批处理将N个调用转换为服务,变成单个调用,该调用将检索一批N个对象。缓存会利用先前获取的同一对象结果,以避免不必要的重复调用。

    1.4K30

    你还在用 REST API 吗?

    抓取不足——这是指 API 端点并没有提供所需的全部信息。因此,客户端必须发出多个请求才能获取应用程序所需的全部内容。 什么是 GraphQL?...除此之外,它还允许我们将不同的实体组合到单个查询中。 GraphQL 的优势 检索精确的数据,无任何多余数据。在 GraphQL 中,可以得到我们所请求的内容,这是一个很大的优势。...GraphQL 的劣势 对于简单的应用程序来说,设置类型、查询等可能有点 复杂,因为使用 REST 可以很容易地完成。 它使用的是 单个端点,而不是遵循 HTTP 规范进行缓存。...要使用 GraphQL 实现相同的效果,我们可以使用类似于这样的查询: query { User(id: '123') { name posts { title } followers { name }...自动缓存 REST 能自动生效缓存,而 GraphQL 则没有自动缓存系统,但是可以借助 Apollo Client、Relay 等客户端实现缓存。

    1.5K10

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

    一、GraphQL介绍 1.1 简介 GraphQL 是一种新的 API 的查询语言,它提供了一种更高效、强大和灵活 API 查询。...查询的返回结果就是输 入的查询结构的精确映射 客户端可以自定义 Api 聚合 如果设计的数据结构是从属的,直接就能在查询语句中指定;即使数据结构是独 立的,也可以在查询语句中指定上下文,只需要一次网络请求...代码即是文档 GraphQL 会把 schema 定义和相关的注释生成可视化的文档,从而使得代码的变更,直接就反映到最新的文档上,避免 RESTful 中手工维护可能会造成代码、 文档不一致的问题 参数类型强校验...聚合查询文章分类信息,分类信息的方式要放在article的schema里面,这样才能聚合查询到 聚合查询结果 查询订单,聚合查询订单关联的商品信息返回 // schema/default.js ...在控制台查看查询结果 在src/main.js配置vue-apollo插件 import VueApollofrom'vue-apollo' Vue.use(VueApollo); 创建Apollo

    5.2K42

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

    所以为了避免误解,后文将把 Query Document(查询文档)称为 Document 或文档。一个 Document 中可包含单个或多个操作,每个操作都可以查询补丁数量的跟字段。...,所以如 query、mutation、subscription 字段是不会出现在返回结果中的,返回结果中的第一层字段是前文提到的 root field(根字段)。...调用合并:经常提到的与 RESTful 相比较优的一点是,当需要获取多个关联数据时,RESTful 接口往往需要多次调用(并发或串行),而基于 GraphQL 的接口调用则可以将调用顺序体现在结构化的查询中...、处理、缓存工作,也在 BFF 层进行过数据模型定义的尝试,同时已经有团队在现有 BFF 中接入了 GraphQL 能力并稳定运行了一段时间。...调用合并:GraphQL 的理念就是将多个查询合并,对应服务端,通常只会提供一个合并后的“大”的接口,那么原本以 URL 为粒度的性能监控、请求追踪就会有问题,可能需要改为以 root field(根字段

    2.3K20

    GraphQL-BFF:微服务背景下的前后端数据交互方案

    要求: 查询语法跟查询结果相近 能精确查询想要的字段 能合并多个请求到一个查询语句 无接口版本管理问题 代码即文档 我们知道查询结果是 JSON 数据格式。...查询语句跟查询结果拥有相同的 key 及其层次结构关系。这是我们想要的。 我们可以再进一步,将冗余的双引号,逗号等部分删掉。 ?...当数据消费方是其它服务时,通过 GraphQL 查询语句,彼此之间可以更精确获取数据,避免冗余的数据传输和接口调用。...我们把多个 GraphQL-Service 的 Schema 整合到一起后,可以生成同样的结果: ?...当我们多个字段要复用相同的逻辑时,编写成中间件,然后将 handler 变成数组形式即可。

    3.8K72

    干货 | 万字长文全面解析GraphQL,携程微服务背景下的前后端数据交互方案

    要求: 1)查询语法跟查询结果相近 2)能精确查询想要的字段 3)能合并多个请求到一个查询语句 4)无接口版本管理问题 5)代码即文档 我们知道查询结果是 JSON 数据格式。...查询语句跟查询结果拥有相同的 key 及其层次结构关系。这是我们想要的。 我们可以再进一步,将冗余的双引号,逗号等部分删掉。 ?...当数据消费方是其它服务时,通过 GraphQL 查询语句,彼此之间可以更精确获取数据,避免冗余的数据传输和接口调用。...我们把多个 GraphQL-Service 的 Schema 整合到一起后,可以生成同样的结果: ?...当我们多个字段要复用相同的逻辑时,编写成中间件,然后将 handler 变成数组形式即可。

    3.8K21

    GraphQL-BFF:微服务背景下的前后端数据交互方案

    要求: 查询语法跟查询结果相近 能精确查询想要的字段 能合并多个请求到一个查询语句 无接口版本管理问题 代码即文档 我们知道查询结果是 JSON 数据格式。...查询语句跟查询结果拥有相同的 key 及其层次结构关系。这是我们想要的。 我们可以再进一步,将冗余的双引号,逗号等部分删掉。 ?...当数据消费方是其它服务时,通过 GraphQL 查询语句,彼此之间可以更精确获取数据,避免冗余的数据传输和接口调用。...我们把多个 GraphQL-Service 的 Schema 整合到一起后,可以生成同样的结果: ?...当我们多个字段要复用相同的逻辑时,编写成中间件,然后将 handler 变成数组形式即可。

    1.6K20

    Meteor开发指南 — 响应式GraphQL

    这篇文章是该设计文档的总结和我对这个项目的一些想法。 这是 GraphQL GraphQL 是一个Facebook提出的应用层的查询语言。...应用的开发者不需要写任何显式的代码来获取那条评论。 这就是响应式GraphQL。你不必重新获取数据或是手动的重新加载网页。 基本上,它就是Meteor但是加上了GraphQL。...响应式GraphQL开发体验 大多数的繁重工作已经被响应式GraphQL库和工具完成了。所以,你只需要简单地在服务端编写GraphQL的数据模式,在客户端编写查询即可。...在客户端,你可以像平常使用GraphQL那样创建查询和调用修改。 为此,你需要使用一个客户端库响应式GraphQL。(它在背后使用Relay作为缓存处理了所有响应式的东西) 就这么简单。...你可以把它理解成一个分布式的版本跟踪服务。 Meteor的计划是把失效服务器作为一个开源项目,并且隶属于响应式GraphQL项目。

    1K100

    REST API和GraphQL API的比较

    GraphQL API GraphQL 是一种用于 API 的查询语言,也是使用现有数据完成这些查询的运行时。...在 GraphQL 架构中,客户端提交查询以获取数据。 典型场景 REST API 假设您有一个 API 来获取学生数据。...表现 开发人员只需一次 API 请求即可使用 GraphQL 获取数据。为了避免数据获取不足和过度获取,灵活的样式定义了信息请求的结构,并从服务器返回相同的结构。...GraphQL 通过单个端点提供,通常是 (/graphql),并且与 HTTP 规范不同。因此,无法像 REST API 那样缓存查询。 但是,由于可用的工具,客户端缓存优于 REST。...一些使用缓存层的客户端(Apollo Client,URQL)使用 GraphQL 的模式和类型系统,允许它们在客户端保留缓存。

    56210
    领券