0

0

JavaScriptGraphQL_Apollo客户端配置详解

狼影

狼影

发布时间:2025-11-21 22:06:56

|

855人浏览过

|

来源于php中文网

原创

首先安装并配置 Apollo Client,创建 HTTP 链接;接着通过 setContext 添加认证请求头;然后使用 onError 处理错误;最后优化缓存策略,提升性能。

javascriptgraphql_apollo客户端配置详解

在现代前端开发中,GraphQL 已成为替代传统 REST API 的主流选择。而 Apollo Client 是目前最流行的 GraphQL 客户端之一,它提供了强大的缓存机制、类型安全支持以及与 React 等框架的无缝集成。本文将详细讲解如何配置 Apollo Client 以连接到 GraphQL 服务,并涵盖常用功能如请求头设置、错误处理、缓存策略等。

1. 安装与基础配置

使用 Apollo Client 前,需要安装核心包和必要的依赖:

npm install @apollo/client graphql

安装完成后,创建一个 ApolloClient 实例并配置基本的 HTTP 链接:

示例代码:

立即学习Java免费学习笔记(深入)”;

import { ApolloClient, InMemoryCache, createHttpLink } from '@apollo/client'; const httpLink = createHttpLink({ uri: 'https://your-graphql-api.com/graphql', // 替换为你的 GraphQL 接口地址 }); const client = new ApolloClient({ link: httpLink, cache: new InMemoryCache(), });

InMemoryCache 是 Apollo 提供的默认缓存系统,能自动缓存查询结果,提升性能并减少重复请求。

2. 设置请求头(如认证 Token)

大多数生产环境的 GraphQL 接口都需要身份验证。可以通过 setContext 添加中间件来动态设置请求头。

常见做法是携带 JWT 认证令牌:

乐彼多用户商城系统LBMall(.net)
乐彼多用户商城系统LBMall(.net)

乐彼多用户商城系统,采用ASP.NET分层技术和AJAX技术,运营于高速稳定的微软.NET+MSSQL 2005平台;完全具备搭建超大型网络购物多用户网上商城的整体技术框架和应用层次LBMall 秉承乐彼软件优秀品质,后台人性化设计,管理窗口识别客户端分辨率自动调整,独立配置的菜单操作锁,使管理操作简单便捷。待办事项1、新订单、支付、付款、短信提醒2、每5分钟自动读取3、新事项声音提醒 店铺管理1

下载
import { ApolloClient, InMemoryCache, createHttpLink, split, HttpLink } from '@apollo/client'; import { setContext } from '@apollo/client/link/context'; const authLink = setContext((_, { headers }) => { const token = localStorage.getItem('authToken'); // 从本地存储获取 token return { headers: { ...headers, authorization: token ? `Bearer ${token}` : '', }, }; }); const httpLink = createHttpLink({ uri: 'https://your-graphql-api.com/graphql', }); const client = new ApolloClient({ link: authLink.concat(httpLink), cache: new InMemoryCache(), });

这里使用了 concat 方法将认证链接与 HTTP 链接组合,确保每次请求都带上授权头。

3. 错误处理(Error Link)

当 GraphQL 请求发生网络错误或服务端返回异常时,应进行统一处理,例如登出用户或提示错误信息。

import { onError } from '@apollo/client/link/error'; const errorLink = onError(({ graphQLErrors, networkError }) => { if (graphQLErrors) { graphQLErrors.forEach(({ message, locations, path }) => { console.error(`[GraphQL Error] Message: ${message}, Path: ${path}`); if (message.includes('invalid token') || message.includes('unauthorized')) { // 可在此清除 token 并跳转登录页 localStorage.removeItem('authToken'); window.location.href = '/login'; } }); } if (networkError) { console.error(`[Network Error]`, networkError); } }); // 组合多个链接:错误处理 -> 认证 -> HTTP 请求 const client = new ApolloClient({ link: errorLink.concat(authLink).concat(httpLink), cache: new InMemoryCache(), });

注意链接顺序很重要,一般按执行顺序排列:先 errorLink,再 authLink,最后 httpLink。

4. 缓存配置优化

Apollo Client 的缓存不仅能提升性能,还能实现离线体验。你可以自定义缓存行为,比如为特定类型设置唯一键。

例如,如果你的 schema 中有 User 类型,可以指定其通过 id 字段作为标识:

const cache = new InMemoryCache({ typePolicies: { User: { keyFields: ['id'], // 使用 id 作为唯一标识 }, Post: { keyFields: ['slug'], // 某些类型可能用 slug 作为主键 }, }, });

对于不希望被缓存的查询,可以在调用 useQuery 时设置 fetchPolicy: 'no-cache''network-only'

基本上就这些核心配置。合理组合链接、正确设置认证与错误处理,再辅以合适的缓存策略,Apollo Client 就能稳定高效地服务于你的应用。

相关专题

更多
什么是中间件
什么是中间件

中间件是一种软件组件,充当不兼容组件之间的桥梁,提供额外服务,例如集成异构系统、提供常用服务、提高应用程序性能,以及简化应用程序开发。想了解更多中间件的相关内容,可以阅读本专题下面的文章。

177

2024.05.11

Golang 中间件开发与微服务架构
Golang 中间件开发与微服务架构

本专题系统讲解 Golang 在微服务架构中的中间件开发,包括日志处理、限流与熔断、认证与授权、服务监控、API 网关设计等常见中间件功能的实现。通过实战项目,帮助开发者理解如何使用 Go 编写高效、可扩展的中间件组件,并在微服务环境中进行灵活部署与管理。

212

2025.12.18

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

738

2023.08.22

php中foreach用法
php中foreach用法

本专题整合了php中foreach用法的相关介绍,阅读专题下面的文章了解更多详细教程。

42

2025.12.04

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

187

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

271

2023.10.25

登录token无效
登录token无效

登录token无效解决方法:1、检查token的有效期限,如果token已经过期,需要重新获取一个新的token;2、检查token的签名,如果签名不正确,需要重新获取一个新的token;3、检查密钥的正确性,如果密钥不正确,需要重新获取一个新的token;4、使用HTTPS协议传输token,建议使用HTTPS协议进行传输 ;5、使用双因素认证,双因素认证可以提高账户的安全性。

6084

2023.09.14

登录token无效怎么办
登录token无效怎么办

登录token无效的解决办法有检查Token是否过期、检查Token是否正确、检查Token是否被篡改、检查Token是否与用户匹配、清除缓存或Cookie、检查网络连接和服务器状态、重新登录或请求新的Token、联系技术支持或开发人员等。本专题为大家提供token相关的文章、下载、课程内容,供大家免费下载体验。

803

2023.09.14

公务员递补名单公布时间 公务员递补要求
公务员递补名单公布时间 公务员递补要求

公务员递补名单公布时间不固定,通常在面试前,由招录单位(如国家知识产权局、海关等)发布,依据是原入围考生放弃资格,会按笔试成绩从高到低递补,递补考生需按公告要求限时确认并提交材料,及时参加面试/体检等后续环节。要求核心是按招录单位公告及时响应、提交材料(确认书、资格复审材料)并准时参加面试。

1

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

React 教程
React 教程

共58课时 | 3.6万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号