首页 > web前端 > js教程 > React 中 graphQL 请求的 Apollo 客户端设置

React 中 graphQL 请求的 Apollo 客户端设置

Mary-Kate Olsen
发布: 2024-11-30 10:17:12
原创
650 人浏览过

Setup Apollo Client para requisições graphQL em React

介绍

本文将展示如何为 graphQL 请求配置 React 应用程序,为此将使用 APollClient 库。这个想法是展示如何配置应用程序以及如何发出请求的示例。

  • @apollo/client:允许您管理状态并使用 GraphQL 发出请求的库
  • graphql:允许解析 GraphQL 查询的库

将库添加到项目中:

yarn add @apollo/client graphql --dev

设置

接下来我将展示如何配置 ApolloClient 以启用 graphQL 请求。
首先,将创建一个 ApolloClient 上下文,以便其子级包含的所有内容都可以发出 graphQL 请求:

import {
  ApolloClient,
  ApolloProvider,
  HttpLink,
  InMemoryCache
} from '@apollo/client'

function ExampleApolloProvider({ children, token, uri }) {
  const httpLink = new HttpLink({
    uri: uri,
    headers: {
      authorization: `Bearer ${token}`,
    },
  })

  const client = new ApolloClient({
    cache: new InMemoryCache(),
    link: httpLink,
  })

  return <ApolloProvider client={client}>{children}</ApolloProvider>
}

export { ExampleApolloProvider as ApolloProvider }
登录后复制
登录后复制

在 const 客户端中,APolloClient 被初始化,传递有关它将从定义的链接命中的位置的信息,以及来自 InMemoryCache 实例的缓存,APolloClient 使用该实例来缓存查询结果。
在 httpLink 中,传递 graphQL api 的 uri,并定义请求所需的标头,在本例中以使用 Bearer 令牌为例。
最后,定义返回和导出以允许在应用程序内使用。

考虑到这是一个登录后将令牌保存在 localStorage 中的应用程序,并且您通常希望允许整个应用程序的 graphQL 请求,因此使用上面文件中定义的 ApolloProvider:

import { ApolloProvider } from './contexts/ApolloContext'
import AppContent from './components/AppContent'

const token = localStorage.getItem('@tokenId')
// endpoint da sua api graphQL
const graphqlURI = 'https://www.example.com'

const App = () => {
  return (
    <ApolloProvider token={token} uri={graphqlURI}>
      <AppContent />
    </ApolloProvider>
  )
}
登录后复制

在本例中,令牌是从 localStorage 中获取的(在本例中,就好像它是使用 @tokenId 键保存的),并且 uri 在文件本身中定义,并传递给 ApolloProvider。 AppContent 作为 ApolloProvider 的子级传递,因此其中包含的所有内容(即整个应用程序)将能够发出 graphQL 请求。
在实践中,具有不同的测试和生产环境,graphqlURI 可以来自使用每个环境的 uri 定义的 env。

从 api 具有的名为 user 的查询开始,该查询返回用户的姓名和职业,将定义包含要调用的查询的文件:

import { gql } from '@apollo/client'

const GET_USER = gql`
  query GetUser {
    user {
      name
      occupation
    }
  }
`

export default GET_USER
登录后复制

GET_USER 对应于 React 应用如何调用查询,以及用户在 api 中搜索的查询的名称。

在定义AppContent的文件中,将调用GET_USER查询并使用其返回:

import {
  ApolloClient,
  ApolloProvider,
  HttpLink,
  InMemoryCache
} from '@apollo/client'

function ExampleApolloProvider({ children, token, uri }) {
  const httpLink = new HttpLink({
    uri: uri,
    headers: {
      authorization: `Bearer ${token}`,
    },
  })

  const client = new ApolloClient({
    cache: new InMemoryCache(),
    link: httpLink,
  })

  return <ApolloProvider client={client}>{children}</ApolloProvider>
}

export { ExampleApolloProvider as ApolloProvider }
登录后复制
登录后复制

useQuery hook 将执行 GET_USER 中定义的查询,当请求未完成时返回 load true,如果请求失败则返回错误,当请求成功完成时返回数据。只要日期尚未返回,屏幕上就会出现“正在加载...”消息。如果请求以错误结束,则会显示消息“请求失败”。如果请求成功完成,用户的姓名和职业(姓名和职业)将会显示在屏幕上。
这样,ApolloClient 就已针对 graphQL 请求进行了配置并可供使用。

结论

这个想法是展示如何配置 APolloClient 以使 React 应用程序能够进行 graphQL 调用,显示上下文的定义、此上下文的使用以及如何执行查询的示例。
对于那些想要深入研究的人,请点击 ApolloClient 文档的链接。

以上是React 中 graphQL 请求的 Apollo 客户端设置的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:dev.to
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板