首页 > web前端 > js教程 > 正文

javascript如何实现网络请求_fetch与axios有何不同

夢幻星辰
发布: 2025-12-22 21:41:02
原创
525人浏览过
fetch是原生API,简洁但需手动处理JSON、错误状态和Cookie;axios是功能完备库,自动解析、拦截器、超时取消等开箱即用;轻量场景选fetch,中大型项目优先axios。

javascript如何实现网络请求_fetch与axios有何不同

JavaScript 实现网络请求最常用的是 fetch(原生 API)和 axios(第三方库),它们都能发起 HTTP 请求,但设计目标、使用方式和默认行为差异明显。

fetch 是浏览器原生支持的 Promise 风格 API

fetch 由浏览器原生提供,无需安装依赖,语法简洁,但默认不带 Cookie、不自动处理 JSON、4xx/5xx 状态码也不会 reject,需手动判断:

  • 必须显式调用 .json().text() 等方法解析响应体
  • 只有网络错误(如断网、DNS 失败)才会触发 catch;HTTP 错误状态(如 404、500)仍走 then,需检查 response.okresponse.status
  • 默认不发送 Cookie,如需携带,要加 credentials: 'include'
  • 没有内置请求/响应拦截、超时控制、取消请求(需配合 AbortController

axios 是功能完备的 HTTP 客户端库

axios 基于 XMLHttpRequest(浏览器)或 http 模块(Node.js),开箱即用,对开发者更友好:

  • 自动识别响应内容类型,JSON 响应默认解析为 JS 对象(无需手动 .json()
  • HTTP 状态码非 2xx 会直接进入 catch(可配置 validateStatus 修改规则)
  • 默认携带 Cookie(同源下),也可统一配置 withCredentials
  • 支持请求/响应拦截器,方便统一加 token、loading、错误提示等
  • 内置超时(timeout)、取消请求(CancelTokenAbortController)、并发控制(axios.all

基础用法对比(GET 请求示例)

fetch:

灵思AI
灵思AI

专业的智能写作辅助平台

灵思AI 202
查看详情 灵思AI

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

fetch('/api/user', {
  method: 'GET',
  credentials: 'include'
})
  .then(res => {
    if (!res.ok) throw new Error(`HTTP ${res.status}`);
    return res.json();
  })
  .then(data => console.log(data))
  .catch(err => console.error(err));
登录后复制

axios:

axios.get('/api/user', {
  withCredentials: true
})
  .then(res => console.log(res.data))
  .catch(err => console.error(err));
登录后复制

选哪个?看场景

  • 项目轻量、只需简单请求、想减少依赖 → 优先用 fetch,搭配 AbortController 和封装工具函数即可补足短板
  • 中大型项目、需要统一拦截、token 管理、错误重试、上传进度、TypeScript 支持更好 → axios 更省心
  • Node.js 环境(无 fetch)或需兼容旧浏览器(IE)→ 只能选 axios

以上就是javascript如何实现网络请求_fetch与axios有何不同的详细内容,更多请关注php中文网其它相关文章!

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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