### 文章目录
- [@[toc]](#文章目录 @[toc] 1. Axios概念 1.1 普通函数&&回调函数 2. Promise概念 3. Promise基本使用方法 3. Promise创造的异步函数如果直接return,默认是resolved状态 4.Promise关键字async&&await 5.Axios异步处理方案 5.1 案例请求:请求后太获取随机土味情话 5.2 异步响应流程小结 5.3 get请求和post请求 6. Axios get和post方法 7. Axios拦截器 7.1 原理 Appendix)
 - [1. Axios概念](#文章目录 @[toc] 1. Axios概念 1.1 普通函数&&回调函数 2. Promise概念 3. Promise基本使用方法 3. Promise创造的异步函数如果直接return,默认是resolved状态 4.Promise关键字async&&await 5.Axios异步处理方案 5.1 案例请求:请求后太获取随机土味情话 5.2 异步响应流程小结 5.3 get请求和post请求 6. Axios get和post方法 7. Axios拦截器 7.1 原理 Appendix)
 - [1.1 普通函数&&回调函数](#文章目录 @[toc] 1. Axios概念 1.1 普通函数&&回调函数 2. Promise概念 3. Promise基本使用方法 3. Promise创造的异步函数如果直接return,默认是resolved状态 4.Promise关键字async&&await 5.Axios异步处理方案 5.1 案例请求:请求后太获取随机土味情话 5.2 异步响应流程小结 5.3 get请求和post请求 6. Axios get和post方法 7. Axios拦截器 7.1 原理 Appendix)
 - [2. Promise概念](#文章目录 @[toc] 1. Axios概念 1.1 普通函数&&回调函数 2. Promise概念 3. Promise基本使用方法 3. Promise创造的异步函数如果直接return,默认是resolved状态 4.Promise关键字async&&await 5.Axios异步处理方案 5.1 案例请求:请求后太获取随机土味情话 5.2 异步响应流程小结 5.3 get请求和post请求 6. Axios get和post方法 7. Axios拦截器 7.1 原理 Appendix)
 - [3. Promise基本使用方法](#文章目录 @[toc] 1. Axios概念 1.1 普通函数&&回调函数 2. Promise概念 3. Promise基本使用方法 3. Promise创造的异步函数如果直接return,默认是resolved状态 4.Promise关键字async&&await 5.Axios异步处理方案 5.1 案例请求:请求后太获取随机土味情话 5.2 异步响应流程小结 5.3 get请求和post请求 6. Axios get和post方法 7. Axios拦截器 7.1 原理 Appendix)
 - [3. Promise创造的异步函数如果直接return,默认是resolved状态](#文章目录 @[toc] 1. Axios概念 1.1 普通函数&&回调函数 2. Promise概念 3. Promise基本使用方法 3. Promise创造的异步函数如果直接return,默认是resolved状态 4.Promise关键字async&&await 5.Axios异步处理方案 5.1 案例请求:请求后太获取随机土味情话 5.2 异步响应流程小结 5.3 get请求和post请求 6. Axios get和post方法 7. Axios拦截器 7.1 原理 Appendix)
 - [4.Promise关键字async&&await](#文章目录 @[toc] 1. Axios概念 1.1 普通函数&&回调函数 2. Promise概念 3. Promise基本使用方法 3. Promise创造的异步函数如果直接return,默认是resolved状态 4.Promise关键字async&&await 5.Axios异步处理方案 5.1 案例请求:请求后太获取随机土味情话 5.2 异步响应流程小结 5.3 get请求和post请求 6. Axios get和post方法 7. Axios拦截器 7.1 原理 Appendix)
 - [5.Axios异步处理方案](#文章目录 @[toc] 1. Axios概念 1.1 普通函数&&回调函数 2. Promise概念 3. Promise基本使用方法 3. Promise创造的异步函数如果直接return,默认是resolved状态 4.Promise关键字async&&await 5.Axios异步处理方案 5.1 案例请求:请求后太获取随机土味情话 5.2 异步响应流程小结 5.3 get请求和post请求 6. Axios get和post方法 7. Axios拦截器 7.1 原理 Appendix)
 - [5.1 案例请求:请求后太获取随机土味情话](#文章目录 @[toc] 1. Axios概念 1.1 普通函数&&回调函数 2. Promise概念 3. Promise基本使用方法 3. Promise创造的异步函数如果直接return,默认是resolved状态 4.Promise关键字async&&await 5.Axios异步处理方案 5.1 案例请求:请求后太获取随机土味情话 5.2 异步响应流程小结 5.3 get请求和post请求 6. Axios get和post方法 7. Axios拦截器 7.1 原理 Appendix)
 - [5.2 异步响应流程小结](#文章目录 @[toc] 1. Axios概念 1.1 普通函数&&回调函数 2. Promise概念 3. Promise基本使用方法 3. Promise创造的异步函数如果直接return,默认是resolved状态 4.Promise关键字async&&await 5.Axios异步处理方案 5.1 案例请求:请求后太获取随机土味情话 5.2 异步响应流程小结 5.3 get请求和post请求 6. Axios get和post方法 7. Axios拦截器 7.1 原理 Appendix)
 - [5.3 get请求和post请求](#文章目录 @[toc] 1. Axios概念 1.1 普通函数&&回调函数 2. Promise概念 3. Promise基本使用方法 3. Promise创造的异步函数如果直接return,默认是resolved状态 4.Promise关键字async&&await 5.Axios异步处理方案 5.1 案例请求:请求后太获取随机土味情话 5.2 异步响应流程小结 5.3 get请求和post请求 6. Axios get和post方法 7. Axios拦截器 7.1 原理 Appendix)
 - [6. Axios get和post方法](#文章目录 @[toc] 1. Axios概念 1.1 普通函数&&回调函数 2. Promise概念 3. Promise基本使用方法 3. Promise创造的异步函数如果直接return,默认是resolved状态 4.Promise关键字async&&await 5.Axios异步处理方案 5.1 案例请求:请求后太获取随机土味情话 5.2 异步响应流程小结 5.3 get请求和post请求 6. Axios get和post方法 7. Axios拦截器 7.1 原理 Appendix)
 - [7. Axios拦截器](#文章目录 @[toc] 1. Axios概念 1.1 普通函数&&回调函数 2. Promise概念 3. Promise基本使用方法 3. Promise创造的异步函数如果直接return,默认是resolved状态 4.Promise关键字async&&await 5.Axios异步处理方案 5.1 案例请求:请求后太获取随机土味情话 5.2 异步响应流程小结 5.3 get请求和post请求 6. Axios get和post方法 7. Axios拦截器 7.1 原理 Appendix)
 - [7.1 原理](#文章目录 @[toc] 1. Axios概念 1.1 普通函数&&回调函数 2. Promise概念 3. Promise基本使用方法 3. Promise创造的异步函数如果直接return,默认是resolved状态 4.Promise关键字async&&await 5.Axios异步处理方案 5.1 案例请求:请求后太获取随机土味情话 5.2 异步响应流程小结 5.3 get请求和post请求 6. Axios get和post方法 7. Axios拦截器 7.1 原理 Appendix)
 - [Appendix](#文章目录 @[toc] 1. Axios概念 1.1 普通函数&&回调函数 2. Promise概念 3. Promise基本使用方法 3. Promise创造的异步函数如果直接return,默认是resolved状态 4.Promise关键字async&&await 5.Axios异步处理方案 5.1 案例请求:请求后太获取随机土味情话 5.2 异步响应流程小结 5.3 get请求和post请求 6. Axios get和post方法 7. Axios拦截器 7.1 原理 Appendix)
 
1. Axios概念
- 
作用: 代替原生js的ajax的解决方案
 - 
axios使用的是promise的一套解决方案
 
1.1 普通函数&&回调函数
普通函数就是我们正常调用的函数

回调函数
回调函数是一种基于事件 的一种自动调用函数
回调函数 及其他代码不会等待回调函数执行完毕;
回调函数:一种未来会执行的函数

2. Promise概念
- 
promise是异步编程的一种解决方案。
 - 
简单来说就是一个容器,里面存放着某个未来才会结束的事件的结果;
 - 
语法上promise是一个对象,可以获取异步操作的消息,promise提供统一的API,各种异步操作都可以用同样的方法进行处理
 - 
promise三种状态
 
Pending(进行中)
Resolved(已完成,又称 Fulfilled)
Rejected(已失败)
- 注意:完成态和失败态状态不会发生改变
 
3. Promise基本使用方法
- promise异步函数定义
 
            
            
              html
              
              
            
          
          let pormise = new Promise(
    function (){
        //此处的代码,和其他代码异步
    }
)
        - 
回调函数封装在promise对象中
 - 
回调函数可以传入两个 形参
- resolve是一个函数,如果回调函数中调用resolve函数,promise会由pending状态转化为resolved状态 也就是进行中转化为已完成状态
 - reject是一个函数,如果回调函数中调用reject函数,promise会由pending状态转化为rejected状态 也就是进行中转化为已完成状态
 
 - 
异步函数中,普通函数是不会等待的;但是promise.then() 定义了当promise对象中的异步代码状态发生改变;才会执行;
 
then函数的形参是 function函数

- 异步函数形参和then函数的形参要保持一致
 

成功就执行成功代码
失败就执行失败代码
- 异步函数的形参("成功","失败")函数是可以传输数据的
 

- 
请注意;promise对象中的异步函数需要写入成功或失败的各个状态
 - 
then函数具有返回值是promiseCatch,也就是说当promise函数执行出现异常 或reject 会执行的函数;异常就是失败状态;
 - 
如果写promseCatch代码,then中即可不需要写reject函数的处理方法
 - 
一步到位的写法
 

3. Promise创造的异步函数如果直接return,默认是resolved状态
4.Promise关键字async&&await
- 
本章节关键字的作用是简化代码,简化Promise使用
- async 帮助获取promise对象
- 先前写法:let promise=new Promise(function(){})
 - 简化写法async function(){}
 - Promise使用就是为了获取异步函数
 
 - await
- 获取成功状态的返回值的
 - await后面的代码会等待await执行完毕继续执行
 - await右边如果是一个失败状态的promise,那么await会直接抛异常
 - 在async定义的函数中 await修饰的方法会阻塞后续方法执行
 
 
 - async 帮助获取promise对象
 - 
Promise创造的异步函数如果直接return,默认是resolved状态,return结果就是成功状态的返回值
 - 
同理状态出现了异常,默认失败状态
 

            
            
              html
              
              
            
          
          小结:
使用async定义成功执行的异步函数
再次async定义异步函数接收的结果
成功结果使用await接收,否则默认失败
await修饰失败 直接报异常,异常后续代码不执行
        5.Axios异步处理方案

5.1 案例请求:请求后太获取随机土味情话
            
            
              html
              
              
            
          
          <script setup>
import axios from 'axios'
  function getLoveMessage(){
    //使用axios发送请求获取data
    // 内部的大括号用于设置内部请求参数 url,请求方式,请求参数等
    let promise = axios({
      method:"get",     url:"https//api.uomg.com/api/rand.qinghua?format=json",
      data : {
      }
    })
    promise.then(
      function (response){
        console.log(response)
        console.log(response.data)
        console.log(response.data.data)
        //assign接收两个对象参数,可以将后面一个的属性值,赋值给前面同名属性值      Object.assign(message,response.data)
      }
    )
  }
</script>
<button @click="getLoveMessage()">
  变
</button>
        5.2 异步响应流程小结
- 绑定js函数
 - 导入axios包,就在axios下
 - 定义响应函数
 - 创建axios对象内部传入json数据包含{请求方式,请求数据}
 - axios返回值是promise对象,使用其then().catch()来处理响应得到的数据
 - 如果响应成功可以响应式数据直接同步到相关位置
 
5.3 get请求和post请求
- 
在请求function中,使用axios发送请求时
 - 
如果请求方式时get并且请求数据写params时,数据会以键值对方式放入请求头中
 - 
如果请求方式是post并且请求数据写data,数据会放到负载中以JSON串形式存在
 - 
实际上,axios中有四个参数;请求方式,url,data,params;data必须跟着post才起作用;params中都是以键值对方式将数据放入url后面键值对形式;
 
6. Axios get和post方法
配置添加语法
            
            
              javascript
              
              
            
          
          axios.get(url[, config])
axios.get(url,{
   上面指定配置key:配置值,
   上面指定配置key:配置值
})
axios.post(url[, data[, config]])
axios.post(url,{key:value //此位置数据,没有空对象即可{}},{
   上面指定配置key:配置值,
   上面指定配置key:配置值
})
        测试get参数
            
            
              html
              
              
            
          
          <script setup type="module">
  import axios from 'axios'
  import { onMounted,ref,reactive,toRaw } from 'vue';
  let jsonData =reactive({code:1,content:'我努力不是为了你而是因为你'})
  let getLoveWords= async ()=>{
    try{
      return await axios.get(
        'https://api.uomg.com/api/rand.qinghua',
        {
          params:{// 向url后添加的键值对参数
            format:'json',
            username:'zhangsan',
            password:'123456'
          },
          headers:{// 设置请求头
            'Accept' : 'application/json, text/plain, text/html,*/*'
          }
        }
      )
    }catch (e){
      return await e
    }
  }
  let getLoveMessage =()=>{
     let {data}  = await getLoveWords()
     Object.assign(message,data)
  }
  /* 通过onMounted生命周期,自动加载一次 */
  onMounted(()=>{
    getLoveMessage()
  })
</script>
<template>
    <div>
      <h1>今日土味情话:{{jsonData.content}}</h1>
      <button  @click="getLoveMessage">获取今日土味情话</button>
    </div>
</template>
<style scoped>
</style>
        测试post参数
            
            
              html
              
              
            
          
          <script setup type="module">
  import axios from 'axios'
  import { onMounted,ref,reactive,toRaw } from 'vue';
  let jsonData =reactive({code:1,content:'我努力不是为了你而是因为你'})
  let getLoveWords= async ()=>{
    try{
      return await axios.post(
        'https://api.uomg.com/api/rand.qinghua',
        {//请求体中的JSON数据
            username:'zhangsan',
            password:'123456'
        },
        {// 其他参数
         	params:{// url上拼接的键值对参数
            	format:'json',
          	},
          	headers:{// 请求头
            	'Accept' : 'application/json, text/plain, text/html,*/*',
            	'X-Requested-With': 'XMLHttpRequest'
          	}
        }
      )
    }catch (e){
      return await e
    }
  }
  let getLoveMessage =()=>{
     let {data}  = await getLoveWords()
     Object.assign(message,data)
  }
  /* 通过onMounted生命周期,自动加载一次 */
  onMounted(()=>{
    getLoveMessage()
  })
</script>
<template>
    <div>
      <h1>今日土味情话:{{jsonData.content}}</h1>
      <button  @click="getLoveMessage">获取今日土味情话</button>
    </div>
</template>
<style scoped>
</style>
        7. Axios拦截器
7.1 原理

如果想在axios发送请 求之前,或者是数据响应回来在执行then方法之前做一些额外的工作,可以通过拦截器完成
            
            
              javascript
              
              
            
          
          // 添加请求拦截器 请求发送之前
axios.interceptors.request.use(
  function (config) {
    // 在发送请求之前做些什么
    return config;
  }, 
  function (error) {
    // 对请求错误做些什么
    return Promise.reject(error);
  }
);
// 添加响应拦截器 数据响应回来
axios.interceptors.response.use(
  function (response) {
    // 2xx 范围内的状态码都会触发该函数。
    // 对响应数据做点什么
    return response;
  }, 
  function (error) {
    // 超出 2xx 范围的状态码都会触发该函数。
    // 对响应错误做点什么
    return Promise.reject(error);
  }
);
        - 定义src/axios.js提取拦截器和配置语法
 
            
            
              javascript
              
              
            
          
          import axios from 'axios'
//  创建instance实例
const instance = axios.create({
    baseURL:'https://api.uomg.com',
    timeout:10000
})
//  添加请求拦截
instance.interceptors.request.use(
    // 设置请求头配置信息
    config=>{
        //处理指定的请求头
        console.log("before request")
        config.headers.Accept = 'application/json, text/plain, text/html,*/*'
        return config
    },
    // 设置请求错误处理函数
    error=>{
        console.log("request error")
        return Promise.reject(error)
    }
)
// 添加响应拦截器
instance.interceptors.response.use(
    // 设置响应正确时的处理函数
    response=>{
        console.log("after success response")
        console.log(response)
        return response
    },
    // 设置响应异常时的处理函数
    error=>{
        console.log("after fail response")
        console.log(error)
        return Promise.reject(error)
    }
)
// 默认导出
export default instance
        - App.vue
 
            
            
              html
              
              
            
          
          <script setup type="module">
  // 导入我们自己定义的axios.js文件,而不是导入axios依赖  
  import axios from './axios.js'
  import { onMounted,ref,reactive,toRaw } from 'vue';
  let jsonData =reactive({code:1,content:'我努力不是为了你而是因为你'})
  let getLoveWords= async ()=>{
    try{
      return await axios.post(
        'api/rand.qinghua',
        {
            username:'zhangsan',
            password:'123456'
        },//请求体中的JSON数据
        {
          params:{
            format:'json',
          }
        }// 其他键值对参数
      )
    }catch (e){
      return await e
    }
  }
  let getLoveMessage =()=>{
    // 这里返回的是一个fullfilled状态的promise
    getLoveWords().then(
        (response) =>{
          console.log("after getloveWords")
          console.log(response)
          Object.assign(jsonData,response.data)
        }
    )
  }
  /* 通过onMounted生命周期,自动加载一次 */
  onMounted(()=>{
    getLoveMessage()
  })
</script>
<template>
    <div>
      <h1>今日土味情话:{{jsonData.content}}</h1>
      <button  @click="getLoveMessage">获取今日土味情话</button>
    </div>
   
</template>
<style scoped>
</style>
        Appendix
1.await函数必须在async函数内部
2.F2键直接重命名文件
            
            
              html
              
              
            
          
          windows也一样使用