javascript中的Fetch API如何使用?【教程】

发布时间 - 2026-01-25 00:00:00    点击率:
Fetch API 默认不带 Cookie、不自动抛错、不将 4xx/5xx 视为异常;Promise 仅在网络失败或 request 构造失败时 reject;需用 response.ok 或 status 判断业务状态;发送 Cookie 需设 credentials 选项;response.json() 等方法不可重入;上传文件勿手动设 Content-Type;必须用 AbortController 控制超时和取消。

Fetch API 不是 Promise 封装的“更高级 axios”,它默认不带 cookie、不自动抛错、不识别 4xx/5xx 状态码为异常——这些不是 bug,是设计选择。

fetch() 返回的 Promise 什么时候会 reject?

只在网络失败(如断网、DNS 错误、请求被 CORS 阻止)、或 request 对象构造失败时 reject。HTTP 状态码如 404500 不会触发 reject,response.ok 才是判断业务成功的可靠依据。

  • 错误写法:fetch('/api/user').then(data => {...}).catch(err => {...}) —— 这里 catch 永远捕获不到 401
  • 正确做法:始终检查 response.okresponse.status
  • 常见坑:用 async/await 却忘了加 if (!res.ok) throw new Error(...)

如何发送带 Cookie 的请求?

默认情况下 fetch 不发送 Cookie,也不接收 Set-Cookie 响应头,必须显式配置 credentials 选项。

  • 要发 Cookie(且后端允许):传 { credent

    ials: 'include' }
  • 仅当 origin 匹配才发(推荐多数场景):用 'same-origin'
  • 完全禁用 Cookie(等价于 XMLHttpRequest 的 withCredentials=false):用 'omit'(默认值)
  • 注意:若设为 'include',后端响应必须带 Access-Control-Allow-Origin: * 不生效,得指定具体域名,且需加 Access-Control-Allow-Credentials: true

如何处理 JSON 响应并避免重复解析?

response.json() 是一个异步方法,只能调用一次;多次调用会报 TypeError: Already read

  • 不要这样:res.json(); res.json() —— 第二次直接失败
  • 安全做法:解析一次,存入变量,后续复用:const data = await res.json()
  • 如果需要同时取 status 和 data,别用 .then(res => res.json()) 链式写法,先解构再处理:if (!res.ok) throw res; const data = await res.json()
  • 注意:res.text()res.blob() 同样不可重入

为什么用 fetch 上传文件却收不到后端解析的字段?

手动构造 FormData 时,fetch 不会自动设置 Content-Type 请求头(浏览器会设为 multipart/form-data; boundary=...),但某些后端框架(如 Express 默认的 body-parser)不解析该类型,导致 req.body 为空。

  • 不要手动设置 headers: { 'Content-Type': 'multipart/form-data' } —— 这会覆盖浏览器自动生成的带 boundary 的 header,导致后端无法解析
  • 正确做法:不设 Content-Type,让浏览器自动处理;后端改用支持 multipart 的中间件(如 Express 的 multer
  • 如果后端只认 application/json,那就别用 FormData,改用 JSON.stringify() + headers: { 'Content-Type': 'application/json' }

最常被忽略的一点:fetch 没有超时控制,也没有原生的 abort-on-unmount 机制,实际项目中必须配合 AbortController 使用,否则组件卸载后仍在处理响应,容易引发 Cannot update a component while rendering a different component 类错误。


# javascript  # java  # js  # json  # cookie  # 浏览器  # app  # access  # axios  # 后端  # ai 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 中山网站制作网页,中山新生登记系统登记流程?  EditPlus中的正则表达式 实战(4)  JavaScript如何实现音频处理_Web Audio API如何工作?  Laravel如何自定义分页视图?(Pagination示例)  大连 网站制作,大连天途有线官网?  EditPlus中的正则表达式 实战(1)  linux写shell需要注意的问题(必看)  微信小程序 scroll-view组件实现列表页实例代码  Laravel如何与Docker(Sail)协同开发?(环境搭建教程)  惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?  简单实现Android文件上传  如何登录建站主机?访问步骤全解析  Android中Textview和图片同行显示(文字超出用省略号,图片自动靠右边)  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  如何快速启动建站代理加盟业务?  SQL查询语句优化的实用方法总结  如何在阿里云香港服务器快速搭建网站?  如何用免费手机建站系统零基础打造专业网站?  详解Android中Activity的四大启动模式实验简述  谷歌Google入口永久地址_Google搜索引擎官网首页永久入口  Laravel DB事务怎么使用_Laravel数据库事务回滚操作  Claude怎样写约束型提示词_Claude约束提示词写法【教程】  Laravel怎么写单元测试_PHPUnit在Laravel项目中的基础测试入门  EditPlus中的正则表达式 实战(2)  Bootstrap CSS布局之列表  Python正则表达式进阶教程_复杂匹配与分组替换解析  Laravel如何连接多个数据库_Laravel多数据库连接配置与切换教程  laravel怎么使用数据库工厂(Factory)生成带有关联模型的数据_laravel Factory生成关联数据方法  实现点击下箭头变上箭头来回切换的两种方法【推荐】  济南网站建设制作公司,室内设计网站一般都有哪些功能?  如何在万网主机上快速搭建网站?  Laravel如何部署到服务器_线上部署Laravel项目的完整流程与步骤  黑客如何利用漏洞与弱口令入侵网站服务器?  网站建设整体流程解析,建站其实很容易!  Laravel怎么配置不同环境的数据库_Laravel本地测试与生产环境动态切换【方法】  如何用搬瓦工VPS快速搭建个人网站?  Android okhttputils现在进度显示实例代码  Laravel怎么解决跨域问题_Laravel配置CORS跨域访问  Linux安全能力提升路径_长期防护思维说明【指导】  网站制作价目表怎么做,珍爱网婚介费用多少?  如何在橙子建站上传落地页?操作指南详解  网站制作大概要多少钱一个,做一个平台网站大概多少钱?  JavaScript模板引擎Template.js使用详解  如何快速辨别茅台真假?关键步骤解析  实例解析angularjs的filter过滤器  如何有效防御Web建站篡改攻击?  LinuxCD持续部署教程_自动发布与回滚机制  详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)  最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?  Laravel怎么实现模型属性的自动加密