前端发送请求之fetch跟axios的区别

embedded/2024/10/20 21:06:53/

        前端开发工程师在针对页面UI设计稿还原之后,还需要与后端开发工程师进行接口对接,发送请求获取后端接口数据后进行逻辑处理呈现给用户。

        常见的发送请求的方式是:Fecth,Axios

        以下概念来自AI

Fecth与Axios的区别:

API的设计:

        Fetch API是基于浏览器内置的 window.fetch 函数,使用起来较为简单,但有些功能需要手动处理,比如对错误的处理。

        Axios 是一个单独的库,提供了更丰富的功能和更方便的API,例如自动处理JSON数据、请求和响应拦截器等。

兼容性:

        Fetch API 在现代浏览器中得到良好支持,但在一些老旧的浏览器中可能需要使用 polyfill 进行兼容处理。

        Axios 兼容性更好,在各种环境中都可以使用,并提供了一致的API。

错误处理:

        在Fetch API中,需要手动检查HTTP响应状态码并处理错误。

        Axios 提供了更简便的错误处理机制,可以通过 .catch 来捕获错误。

举例说明:

Fetch API

// 用例一
fetch(url, {method: 'GET', // 请求方法headers: {'Content-Type': 'application/json', // 请求头// 其他自定义请求头},body: JSON.stringify(data), // 请求体,通常用于 POST 或 PUT 请求
})
.then(response => response.json()) // 处理响应数据
.then(data => {// 处理获取到的数据
})
.catch(error => {// 处理错误
});// 用例二
fetch('https://api.example.com/data')
.then(response => response.json())
.then(data => {console.log(data);
})
.catch(error => {console.error('Error:', error);
});

Axios

// 用例一
axios({method: 'GET', // 请求方法url: 'https://api.example.com/data', // 请求地址headers: {'Content-Type': 'application/json', // 请求头// 其他自定义请求头},data: requestData, // 请求体,通常用于 POST 或 PUT 请求
})
.then(response => {// 处理响应数据console.log(response.data);
})
.catch(error => {// 处理错误console.error('Error:', error);
});// 用例二
axios.get('https://api.example.com/data')
.then(response => {console.log(response.data);
})
.catch(error => {console.error('Error:', error);
});


http://www.ppmy.cn/embedded/12295.html

相关文章

vue 3 + TS 组合式标注类型

1.组件的 emits 标注类型 <script setup lang"ts"> // 运行时 const emit defineEmits([change, update])// 基于选项 const emit defineEmits({change: (id: number) > {// 返回 true 或 false// 表明验证通过或失败},update: (value: string) > {//…

MATLAB 数据类型

MATLAB 数据类型 MATLAB 不需要任何类型声明或维度语句。每当 MATLAB 遇到一个新的变量名&#xff0c;它就创建变量并分配适当的内存空间。 如果变量已经存在&#xff0c;那么MATLAB将用新内容替换原始内容&#xff0c;并在必要时分配新的存储空间。 例如&#xff0c; Tota…

盲人辅助器具生产新突破:赋能独立出行

作为一名记者&#xff0c;我有幸记录下盲人朋友借助一款名为蝙蝠避障的辅助出行应用&#xff0c;结合配套专用设备&#xff0c;实现独立、无障碍出行的生动场景。这款应用与设备的组合&#xff0c;以盲人辅助器具生产的最新成果&#xff0c;为视障人士带来前所未有的出行便利与…

❤ vue 使用原生组件

❤ vue 使用原生组件 1、input输入框 ① 想让我们的input输入框类型为时间&#xff0c;只需要为我们的输入框简单的加一个类型的type即可 <input type"date" id"birthday" name"birthday" placeholder"年/月/日"> 我们还可以…

负载均衡原理

一、什么是负载均衡&#xff1f; 互联网早期&#xff0c;业务流量比较小并且业务逻辑比较简单&#xff0c;单台服务器便可以满足基本的需求&#xff1b;但随着互联网的发展&#xff0c;业务流量越来越大并且业务逻辑也越来越复杂&#xff0c;单台机器的性能问题以及单点问题凸显…

(超级详细)JAVA之Stream流分析-------持续更新喔!!!

学习目标&#xff1a; 掌握 Java Stream流的相关api 掌握 Java Stream流的基本实现 掌握 java Stream流的使用场景 代码已经整理上传到了gitee中&#xff0c;有需要的小伙伴可以取查看一下源码点个小心心喔 大家也可以帮我提交一点案例喔&#xff01;&#xff01;&#xff01;&…

无人机飞行特点

你知道吗&#xff1f;无人机飞行竟然有这么多的神奇特点&#xff01; &#x1f929;想象一下&#xff0c;它们如同天空中的自由精灵&#xff0c;不受束缚地穿梭在云端。 &#x1f681; 首先&#xff0c;无人机的飞行高度和角度都可以随心所欲地调整&#xff0c;无论是俯瞰美景…

山东专升本计算机基础 --- Windows 10 操作系统安全

文章目录 Windows 10 操作系统安全1、Windows 10 系统安装的安全2、系统帐户安全3、应用安全策略4、网络安全策略 Windows 10 操作系统安全 1、Windows 10 系统安装的安全 操作系统的安全和安装操作系统的选项密切相关。 选择 NTFS 文件格式分区组件的定制安装 Windows 10 …