添加链接
link管理
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接
Skip to content
Vue Apollo

查询

获取数据涉及使用标准 GraphQL 文档执行 query 操作。你可以在 这里 在 playground 上实践查询的运行 上了解有关查询和 GraphQL 文档的更多信息。

执行一个查询

GraphQL 文档

在本节中,我们以这个 GraphQL 文档为例:

TIP

建议为 GraphQL 操作命名(此处为 getUsers ),这样在 Apollo Client 开发工具中能更容易找到它们。

该查询将返回包含一个 users 数组的一个 data 对象,数组中包括 id firstname lastname email 。它可能看起来像这样:

你可能会问:为什么在 data 上有一个嵌套的 users 属性?为什么数组不直接放在 data 上?

这是因为你可以在 GraphQL 操作中选择多个根字段:

在这种情况下,结果可能如下所示:

结果中除了 data 以外,还会存在以下可选属性:

  • errors :服务器返回的一系列错误
  • extensions :附加信息,例如执行时间

useQuery

用于执行查询的主要组合函数是 useQuery 。首先在组件中导入它:

你可以在 setup 选项中使用 useQuery ,并将 GraphQL 文档作为第一个参数传递给它。然后取回查询 result

注意这里的 result 是一个 Ref ,用于保存 Apollo 返回结果中的数据。

如果要直接访问数据对象,请使用 result.value

在当前示例中,你还可以直接侦听 Ref

让我们将结果暴露给模板:

注意 result 可能不会一直包含你的数据!初始值将是 undefined ,直到查询成功完成。因此最好在渲染数据之前添加条件代码:

查询状态

加载状态

useQuery result 旁边还会返回 loading ,一个布尔值 Ref 来跟踪查询的加载状态:

错误

还有一个 error Ref 包含在请求期间可能发生的任何错误:

变量

你可以把一个变量对象作为第二个参数传递给 useQuery

变量 Ref

之后你可以通过检索它们的 variables Ref 来更改它们:

TIP

每次 variables 对象的属性更改时,都会重新获取查询。

另外,你可以直接传递 Ref

响应式对象

你也可以传递一个响应式对象:

这也意味着你可以直接传递 setup 里的 props ,因为 props 已经是一个响应式对象:

但是请注意,如果你添加了 GraphQL 文档中未使用的新属性,就会遇到 GraphQL 验证错误!

变量函数

最后,你可以将传递一个返回对象的函数作为变量:

该变量函数将自动成为响应式的,因此每当 props.id 更改时,查询的 variables 对象也将被更新。

如果你想要在 variables 中使用一些 Ref ,此语法也很有用:

选项

useQuery 的第三个参数是一个选项对象,用于配置你的查询。

variables 一样,你可以传递一个 Ref ,一个响应式对象或一个自动响应式的函数。

使用 Ref

使用响应式对象:

使用自动响应式的函数:

API 参考 查看所有可用的选项。

禁用查询

你可以使用 enabled 选项来禁用和重新启用查询:

获取策略

fetchPolicy 选项可以让你自定义如何使用 Apollo Client 来缓存查询。

可用值为:

  • cache-first (默认):从缓存返回结果。仅当无法获得缓存结果时才从网络获取。
  • cache-and-network :首先从缓存中返回结果(如果存在),然后在网络可用时返回网络结果。
  • cache-only :从缓存返回结果(如果可用),否则失败。
  • network-only :从网络返回结果并保存到缓存,如果网络调用未成功则失败。
  • no-cache :从网络返回结果但不保存到缓存,如果网络调用未成功则失败。

更新缓存结果

查询完成后,它将使用结果数据来更新缓存(取决于 获取策略 )。这将提升下一次需要在应用中渲染数据时的性能,并确保所有依赖同一条数据的组件始终保持一致。

但是,有时你需要确保此数据与服务器相比是最新的。

轮询

轮询是指反复调用服务器以自动更新查询数据。

你可以使用 pollInterval 来启用轮询,它将是每次重复向服务器发出请求的间隔,以毫秒为单位。

在此示例中,我们将每秒轮询一次服务器:

重新获取

另一种方法是响应事件来再次手动执行查询,而非使用固定的时间间隔。

这是通过 refetch 函数完成的:

事件钩子

useQuery 返回事件钩子,允许你在特定事件发生时执行代码。

onResult

将在有新结果可用时调用。

你可以传递 notifyOnNetworkStatusChange 选项,以强制查询在网络状态或错误更新时触发新结果:

onError

发生错误时触发:

你可以使用 @vue/apollo-util 包中的 logErrorMessages 函数在浏览器控制台中对错误进行格式化:

错误示例:

错误日志截图

如果你使用的是 Webpack 或 Vue CLI,则最好仅在开发环境中使用它: