Axios基础用法

Axios简介?

        Axios是一个基于Promise的HTTP库,可以用在浏览器和node.js中。

        Axios提供了更简洁、更强大的API来处理HTTP请求,因此在Vue.js或React等Javascript框架中十分受欢迎。

json-server

        json-server是一个命令行工具,可以让你快速地从一个JSON文件创建一个API。它提供了一个简单的HTTP服务器,用于读取和写入JSON文件,在学习过程中可以使用它进行模拟数据请求。

    下载json-server

     下载json-server之前要确保你已经安装了npm和Node.js。我们可以使用npm install -g json-server在对应的终端中下载,如下图:

ec77321ef3b947b1bdea74e4e1259065.png

        下载成功:

f4e96ebe2ef4491590e5d75c71b4e094.png

    创建模拟数据json文件

        我们需要在下载了json-server的文件夹目录下创建一个.json文件(文件名可以随便取,后缀是.json就行)。

        在bk_json目录下创建json文件:

9ad7266afc9f41aa95bf0785fd34d0be.png

        db.json文件中:

{   
    // 一个people数组,里面的每一个{}可以看作一个people对象
    "people": [
        {
            "name": "张三",
            "age": 20
        },
        {
            "name": "李四",
            "age": 21
        },
        {
            "name": "王五",
            "age": 22
        }
    ],
    
    // 一个cat数组,里面的每一个{}可以看作一个cat对象
    "cat": [
        {
            "name": "小白",
            "age": 3
        },
        {
            "name": "小黑",
            "age": 6
        }
    ]
}

    运行json-server

        在命令行中运行 json-server --watch db.json 指令启动服务器。

        启动后:可以通过Endpoints下面的路径查看json文件中的数据。

147dfa0fb7294a598831ed5e1070f163.png

bcdc2c1e9ac3423ab03077620df00055.png4cc09d796dfe437096b2fae5c92d5039.png

安装Axios

        1、使用 npm:

npm install axios

        2、使用 bower:

bower install axios

        3、使用 yarn:

yarn add axios

Axios基础用法

        Axios的基础用法包括get、post、put、delete、并发。这些基础用法可以实现对服务器数据的增删改查。

        Axios一般在前端框架中使用,在这里我使用的是Vue.js。

    创建Vue项目

        创建Vue项目,在需要使用的组件中引入axios便可以使用axios向服务器发送HTTP请求。

c643ed55ed6d4b6f9685b8f7c0c692e9.png

import axios from 'axios'

    get请求

        get请求主要用于向服务器请求数据。

        使用get请求获取服务器中的people数据:

<script>
import axios from 'axios'

export default {
  name: 'App',
  mounted () {  //此处的路径是上面的服务器启动后得到的路径,如果想获取cat的数据,可以将people改成cat。
    axios.get('http://localhost:3000/people').then((res) => {
      console.log(res);
    })
  }
}
</script>

           请求结果:

92741582197d4bf98da16fefd9e3b880.png

    post请求

        post请求主要用于向服务器发送数据,以便创建或更新资源。与get请求不同,post请求通常用于提交表单数据、上传文件或创建新的资源实例。

        使用post请求向cat中添加新的对象:

        第一种方法:直接将数据写到post方法中。

<script>
import axios from 'axios'

export default {
  name: 'App',
  mounted () {  
    axios.post('http://localhost:3000/cat',{
      name: "土豆",
      age: 6
    }).then((res) => {
      console.log(res);
    })
  }
}
</script>

     第二种方法:创建一个data对象,将数据放入data对象,再将data对象放到post方法中。

<script>
import axios from 'axios'

export default {
  name: 'App',
  mounted () {  

    let data = {
      name: '土豆',
      age: 6
    }

    axios.post('http://localhost:3000/cat',data).then((res) => {
      console.log(res);
    })
  }
}
</script>

          结果:

e0d3256a7b6f4d61be349aa614c9f332.png0faf1c87d6544db08fc22d86310a7c60.png

    put请求

        put请求主要用于更新服务器现有的数据。

        使用put请求更新上面使用post请求添加的cat对象:

<script>
import axios from 'axios'

export default {
  name: 'App',
  mounted () {  

    const data = { //修改后的数据信息
      name: "小红",
      age: 12
    }

                                       //此处的240f是需要修改的数据的唯一标识
    axios.put('http://localhost:3000/cat/240f',data).then((res) => {
      console.log(res);
    })
  }
}
</script>

        结果:

45f7c0e3b67f4752ad9696da41df1aeb.png4858b076251c44188aba0c4ade833a60.png

    delete请求

        delete请求用于请求服务器删除指定数据。

        使用delete请求删除上面使用post请求添加的cat对象:

<script>
import axios from 'axios'

export default {
  name: 'App',
  mounted () {  
    axios.delete('http://localhost:3000/cat/240f').then((res) => {
      console.log(res);
    })
  }
}
</script>

        结果:

85b1a5e530ad411885f3b053628b4f98.png8e55565a14dc46c29620bfbcc69f2ed6.png

    并发请求

        axios的并发请求允许我们同时发送多个HTTP请求,并在所有请求完成(或失败)后返回结果。

        使用并发请求同时请求上面的服务器中的people和cat数据并在控制台上输出:

<script>
import axios from 'axios'

export default {
  name: 'App',
  mounted () {  
    axios.all([
      axios.get('http://localhost:3000/people'),
      axios.get('http://localhost:3000/cat')
    ]).then((res1,res2) => {
      console.log(res1,res2);
    })
  }
}
</script>

        结果:

9721be7c82dc494eb8446b754b78094f.png

总结

        Axios对于向服务器请求数据非常方便,其强大的API比之传统的HTTP更易于上手。Axios的基础用法是我们学习Axios其他高级用法之前必须学习的,它们能够实现对服务器数据基本的增删改查操作,为我们使用Vue等前端框架开发时提供了极大的便利。在页面开发时,一些地方的数据信息可以实现灵活修改而不是像以前一样将数据写死。总之,Axios对于前端开发来说至关重要,它能够使前端可以获取后端数据,实现数据的实时更新。

 

 

相关推荐

  1. axios

    2024-06-16 13:20:02       12 阅读
  2. Vue3实战笔记(06)--- Axios 基本

    2024-06-16 13:20:02       16 阅读
  3. vue开发,axios网络请求框架基本和封装

    2024-06-16 13:20:02       33 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-06-16 13:20:02       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-16 13:20:02       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-16 13:20:02       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-16 13:20:02       20 阅读

热门阅读

  1. 洛谷题解 - P1036 [NOIP2002 普及组] 选数

    2024-06-16 13:20:02       7 阅读
  2. 深度神经网络

    2024-06-16 13:20:02       6 阅读
  3. ubantu 计算一个文件夹内的文件数量命令

    2024-06-16 13:20:02       9 阅读
  4. vue2和vue 3 的响应式原理

    2024-06-16 13:20:02       6 阅读
  5. 博客摘录「 YOLOv5模型剪枝压缩」2024年5月11日

    2024-06-16 13:20:02       8 阅读
  6. 主流排序算法——python

    2024-06-16 13:20:02       6 阅读
  7. make menuconfig 分析

    2024-06-16 13:20:02       7 阅读
  8. leecode N皇后

    2024-06-16 13:20:02       8 阅读
  9. HTML基础标签解析:H1-H6、DIV与P的正确使用方法

    2024-06-16 13:20:02       7 阅读
  10. Vue3 中 props 与 emit 用法

    2024-06-16 13:20:02       7 阅读
  11. django orm 查询返回指定关键字

    2024-06-16 13:20:02       8 阅读
  12. 【AI原理解析】— 星火大模型

    2024-06-16 13:20:02       7 阅读