编写一个简易的 Axios 函数

编写一个简易的 Axios 函数:从零开始创建你自己的网络请求工具

当我们开始构建自己的网络请求工具时,不禁思考着:在现代的网络开发中,Axios等工具库如此受欢迎,其背后的原理是什么?这篇文章将带你踏上一个旅程,逐步构建一个简单但功能强大的 Axios 类型函数。

预备知识

在开始之前,让我们回顾一下基础知识。我们将使用原生 JavaScript 来实现这个功能,因此了解 XMLHttpRequest 对象以及 Promises 如何工作将会非常有帮助。

设定目标

我们的目标是构建一个名为 myAxios 的函数。这个函数将接收一个配置对象,并返回一个 Promise 对象,使得我们可以优雅地处理异步网络请求。

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>封装_简易axios函数_获取省份列表</title>
</head>

<body>
  <p class="my-p"></p>
  <script>
    /**
     * 目标:封装_简易axios函数_获取省份列表
     *  1. 定义myAxios函数,接收配置对象,返回Promise对象
     *  2. 发起XHR请求,默认请求方法为GET
     *  3. 调用成功/失败的处理程序
     *  4. 使用myAxios函数,获取省份列表展示
    */
    // 1. 定义myAxios函数,接收配置对象,返回Promise对象
    function myAxios(config) {
      return new Promise((resolve, reject) => {
        // 2. 发起XHR请求,默认请求方法为GET
        const xhr = new XMLHttpRequest()
        xhr.open(config.method || 'GET', config.url)
        xhr.addEventListener('loadend', () => {
          // 3. 调用成功/失败的处理程序
          if (xhr.status >= 200 && xhr.status < 300) {
            resolve(JSON.parse(xhr.response))
          } else {
            reject(new Error(xhr.response))
          }
        })
        xhr.send()
      })
    }

    // 4. 使用myAxios函数,获取省份列表展示
    myAxios({
      url: 'http://hmajax.itheima.net/api/province'
    }).then(result => {
      console.log(result)
      document.querySelector('.my-p').innerHTML = result.list.join('<br>')
    }).catch(error => {
      console.log(error)
      document.querySelector('.my-p').innerHTML = error.message
    })
  </script>
</body>

</html>

相关推荐

  1. 编写一个简易 Axios 函数

    2023-12-14 06:04:04       58 阅读
  2. 实现简易 axios

    2023-12-14 06:04:04       46 阅读
  3. Axios简明教程

    2023-12-14 06:04:04       35 阅读
  4. 一个用Kotlin编写简易串行任务调度器

    2023-12-14 06:04:04       35 阅读
  5. 一个简单自执行函数--webpack

    2023-12-14 06:04:04       36 阅读
  6. Python基础语法:使用Python编写一个简单计算器

    2023-12-14 06:04:04       65 阅读
  7. 编写一个简单服务和客户端(C++)

    2023-12-14 06:04:04       55 阅读

最近更新

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

    2023-12-14 06:04:04       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-14 06:04:04       106 阅读
  3. 在Django里面运行非项目文件

    2023-12-14 06:04:04       87 阅读
  4. Python语言-面向对象

    2023-12-14 06:04:04       96 阅读

热门阅读

  1. C++中的接口有什么用

    2023-12-14 06:04:04       58 阅读
  2. 服务器数据被盗了该怎么办

    2023-12-14 06:04:04       65 阅读
  3. 51.0/表单(详细版)

    2023-12-14 06:04:04       59 阅读
  4. react中MQTT的基础用法

    2023-12-14 06:04:04       56 阅读
  5. 跟着官网学 Vue - Props

    2023-12-14 06:04:04       54 阅读
  6. 使用python的socketserver使服务器支持多客户端访问

    2023-12-14 06:04:04       57 阅读
  7. 常见的工作流编排引擎

    2023-12-14 06:04:04       75 阅读
  8. C#中UDP的简单使用+样例

    2023-12-14 06:04:04       61 阅读
  9. Spark读写Hive

    2023-12-14 06:04:04       60 阅读