本文将展示如何为 graphQL 请求配置 React 应用程序,为此将使用 APollClient 库。这个想法是展示如何配置应用程序以及如何发出请求的示例。
将库添加到项目中:
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中文网其他相关文章!