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

        前端开发工程师在针对页面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);
});

相关推荐

  1. 前端发送请求fetchaxios区别

    2024-04-24 08:44:02       40 阅读
  2. fetchaxios区别

    2024-04-24 08:44:02       46 阅读
  3. 请求封装(axiosfetch

    2024-04-24 08:44:02       59 阅读
  4. fetchaxios 和 XMLHttpRequest区别

    2024-04-24 08:44:02       55 阅读
  5. Ajax、FetchAxios三者区别

    2024-04-24 08:44:02       42 阅读
  6. 前端如何中断请求 ( axios、原生 ajax、fetch)

    2024-04-24 08:44:02       59 阅读
  7. 前端Ajax、AxiosFetch用法和区别笔记

    2024-04-24 08:44:02       28 阅读
  8. 【实例】Ajax、AxiosFetch区别

    2024-04-24 08:44:02       39 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-24 08:44:02       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-24 08:44:02       106 阅读
  3. 在Django里面运行非项目文件

    2024-04-24 08:44:02       87 阅读
  4. Python语言-面向对象

    2024-04-24 08:44:02       96 阅读

热门阅读

  1. ubuntu2004,自动安装mysql5.7.37

    2024-04-24 08:44:02       33 阅读
  2. Rust并发编程实践:10分钟入门系统级编程

    2024-04-24 08:44:02       26 阅读
  3. 团队合作和独立的理解

    2024-04-24 08:44:02       96 阅读
  4. 如何写好SQL

    2024-04-24 08:44:02       29 阅读
  5. 理解CSS中的sticky与fixed定位

    2024-04-24 08:44:02       114 阅读