您的位置:首页 > 娱乐 > 明星 > 19_axios入门到进阶

19_axios入门到进阶

2025/4/17 17:02:23 来源:https://blog.csdn.net/m0_52474839/article/details/139642357  浏览:    关键词:19_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. Axios概念

  • 作用: 代替原生js的ajax的解决方案

  • axios使用的是promise的一套解决方案

1.1 普通函数&&回调函数

普通函数就是我们正常调用的函数

在这里插入图片描述

回调函数

回调函数是一种基于事件 的一种自动调用函数

回调函数 及其他代码不会等待回调函数执行完毕;

回调函数:一种未来会执行的函数

在这里插入图片描述

2. Promise概念

  • promise是异步编程的一种解决方案。

  • 简单来说就是一个容器,里面存放着某个未来才会结束的事件的结果;

  • 语法上promise是一个对象,可以获取异步操作的消息,promise提供统一的API,各种异步操作都可以用同样的方法进行处理

  • promise三种状态

Pending(进行中)

Resolved(已完成,又称 Fulfilled)

Rejected(已失败)

  • 注意:完成态和失败态状态不会发生改变

3. Promise基本使用方法

  • promise异步函数定义
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修饰的方法会阻塞后续方法执行
  • Promise创造的异步函数如果直接return,默认是resolved状态,return结果就是成功状态的返回值

  • 同理状态出现了异常,默认失败状态

在这里插入图片描述

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

5.Axios异步处理方案

在这里插入图片描述

5.1 案例请求:请求后太获取随机土味情话

<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方法

配置添加语法

axios.get(url[, config])axios.get(url,{上面指定配置key:配置值,上面指定配置key:配置值
})axios.post(url[, data[, config]])axios.post(url,{key:value //此位置数据,没有空对象即可{}},{上面指定配置key:配置值,上面指定配置key:配置值
})

测试get参数

<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参数

<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方法之前做一些额外的工作,可以通过拦截器完成

// 添加请求拦截器 请求发送之前
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提取拦截器和配置语法
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
<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状态的promisegetLoveWords().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键直接重命名文件

windows也一样使用

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com