当前位置: 首页 > news >正文

09-axios在Vue中的导入与配置

09-axios

  • 前言
  • 首先简单了解什么是Axios?
    • 以上完成后就可以使用了

前言

我们接着上一篇文章 08-路由地址的数据获取 来讲。


下一篇文章 10-vuex在Vue中的导入与配置

首先简单了解什么是Axios?

Axios是一个基于Promise 用于浏览器和 nodejs 的 HTTP 客户端,本质上也是对原生XHR的封装,只不过它是Promise的实现版本,符合最新的ES规范。

关于axios的特点,可以查看axios中文文档,还可以了解一下axios, ajax和fetch的详细比较内容。

接下来开始安装axios,在项目目录下执行npm i axios(不同的node版本,成功后的提示不同)

在这里插入图片描述

安装成功后进行引入,在项目目录下src文件夹里创建新的utils文件夹,然后,在文件夹里创建axios.js

/utils/axios.js

/axios/index.js

/utils/request.js

// 1、引入axios内容
import axios from 'axios'// 2、设置请求默认内容
// 请求服务器地址
axios.defaults.baseURL = 'https://www.xxxx.com:8080'
// 跨域请求是否提供凭据信息(cookie、HTTP认证及客户端SSL证明等),也可以简单的理解为,当前请求为跨域类型时是否在请求中协带cookie。
axios.defaults.withCredentials = true
// 请求头中X-Requested-With字段值为XMLHttpRequest
axios.defaults.headers['X-Requested-With'] = 'XMLHttpRequest'
// 请求头中携带token值
axios.defaults.headers['token'] = localStorage.getItem('token') || ''
// 使用post请求时,发送的数据类型(Content-Type)为 application/json
axios.defaults.headers.post['Content-Type'] = 'application/json'// axios使用拦截器,我们下面会讲一下拦截器的定义
axios.interceptors.response.use(res => {// 服务器返回值非正常情况下执行的代码if (typeof res.data !== 'object') {alert('服务器异常!')return Promise.reject(res)}if (res.data.resultCode != 200) { // 浏览器状态码不为200(正常)if (res.data.message) alert(res.data.message)  //判断是否有错误信息,有则打印错误信息if (res.data.resultCode == 416) { // 浏览器状态码为416(未登录)alert('未登录,请先登录!')}return Promise.reject(res.data)}// 服务器返回值正常情况下执行的代码return res.data
})
// 导出axios 实例
export default axios
// 1、引入axios内容
import axios from 'axios'// 2、设置请求默认内容
// 请求服务器地址
axios.defaults.baseURL = 'https://www.xxxx.com:8080'
// 跨域请求是否提供凭据信息(cookie、HTTP认证及客户端SSL证明等),也可以简单的理解为,当前请求为跨域类型时是否在请求中协带cookie。
axios.defaults.withCredentials = true
// 请求头中X-Requested-With字段值为XMLHttpRequest
axios.defaults.headers['X-Requested-With'] = 'XMLHttpRequest'
// 请求头中携带token值
//axios.defaults.headers['token'] = localStorage.getItem('token') || ''
// 使用post请求时,发送的数据类型(Content-Type)为 application/json
axios.defaults.headers.post['Content-Type'] = 'application/json'axios.interceptors.request.use(config => {config.headers['token'] = localStorage.getItem('token') || '';return config
})// axios使用拦截器,我们下面会讲一下拦截器的定义
axios.interceptors.response.use(res => {// 服务器返回值非正常情况下执行的代码// if (typeof res.data !== 'object') {//   alert('服务器异常!')//   return Promise.reject(res)// }// if (res.data.resultCode != 200) { // 浏览器状态码不为200(正常)//   if (res.data.message) alert(res.data.message)  //判断是否有错误信息,有则打印错误信息//   if (res.data.resultCode == 416) { // 浏览器状态码为416(未登录)//     alert('未登录,请先登录!')//   }//   return Promise.reject(res.data)// }// 服务器返回值正常情况下执行的代码return res.data
})
// 导出axios 实例
export default axios

关于拦截器

​ 如果我们使用中需要统一处理所有 http 请求和响应, 就需要使用 axios 拦截器。

使用拦截器的原因:

​ 若出现请求数多的情况下,我们将会用到 axios 的一个API:拦截器。
​ 页面发送http请求,很多情况我们要对请求和其响应进行特定的处理,
​ 如果每个请求都附带后端返回的token,我们需要在拿到response之前loading动画的展示等。

拦截器的分类:

​ 拦截器分为 请求(request)拦截器和 响应(response)拦截器。

以上完成后就可以使用了

接下来以get请求为例,使用方式如下:

this.axios.get(url).then(res => {//请求成功,触发then中的函数console.log(res)  }).catch(error =>//请求失败,触发catch中的函数 可省略console.log(error))

某商城的API接口:http://backend-api-01.newbee.ltd/api/v1/index-infos

<template><div id="app"><ul><li v-for="(good, index) in list" :key="index">{{ good }}</li></ul></div>
</template><script>import axios from "./utils/axios";
export default {data() {return {list: [],};},mounted(){axios.get("http://backend-api-01.newbee.ltd/api/v1/index-infos").then(res => {console.log(res);this.list = res.data.hotGoodses})}
};
</script>

请求结果自行判断

关于post请求方式与get类似,不同点在于地址url和参数params分开传递,使用方式如下:

axios.post(url, params).then(res => {//请求成功,触发then中的函数console.log(res)  }).catch(error =>//请求失败,触发catch中的函数 可省略console.log(error))

相关文章:

  • SGPT论文阅读笔记
  • 周末总结(2024/06/22)
  • 14K屏FPGA通过MIPI接口点亮
  • 编程书籍的枯燥真相:你也有同样的感受吗?
  • 什么是距离选通型水下三维激光扫描仪?(下)
  • AU音频重新混合音频,在 Adobe Audition 中无缝延长背景音乐,无缝缩短BGM
  • Markdown基础教程
  • 用AI绘画-Stable Diffusion稳定生成指定人物的2-3人场景图,制作小说配图从未如此轻松!
  • 【经验分享】RT600 serial boot mode测试
  • textarea标签改写为富文本框编辑器KindEditor
  • 基于java+springboot+vue实现的智慧生活商城系统(文末源码+Lw)244
  • JVM 性能分析案列——使用 JProfiler 工具分析 dump.hprof 堆内存快照文件排查内存溢出问题
  • Android网络收集和ping封装库
  • AI大眼萌探索 AI 新世界:Ollama 使用指南【1】
  • windows下mysql修改 my.ini的datadir后 `Access denied`
  • #Java异常处理
  • 《网管员必读——网络组建》(第2版)电子课件下载
  • 78. Subsets
  • angular2 简述
  • angular学习第一篇-----环境搭建
  • CNN 在图像分割中的简史:从 R-CNN 到 Mask R-CNN
  • emacs初体验
  • jquery cookie
  • nfs客户端进程变D,延伸linux的lock
  • uni-app项目数字滚动
  • Vue学习第二天
  • 半理解系列--Promise的进化史
  • 第十八天-企业应用架构模式-基本模式
  • 讲清楚之javascript作用域
  • 开放才能进步!Angular和Wijmo一起走过的日子
  • 一些关于Rust在2019年的思考
  • k8s使用glusterfs实现动态持久化存储
  • 第二十章:异步和文件I/O.(二十三)
  • 组复制官方翻译九、Group Replication Technical Details
  • ​软考-高级-信息系统项目管理师教程 第四版【第19章-配置与变更管理-思维导图】​
  • #define
  • #VERDI# 关于如何查看FSM状态机的方法
  • #职场发展#其他
  • (1)常见O(n^2)排序算法解析
  • (12)Hive调优——count distinct去重优化
  • (C)一些题4
  • (安全基本功)磁盘MBR,分区表,活动分区,引导扇区。。。详解与区别
  • (二)pulsar安装在独立的docker中,python测试
  • (蓝桥杯每日一题)平方末尾及补充(常用的字符串函数功能)
  • (六)Hibernate的二级缓存
  • (十七)Flask之大型项目目录结构示例【二扣蓝图】
  • (算法)求1到1亿间的质数或素数
  • (学习日记)2024.04.04:UCOSIII第三十二节:计数信号量实验
  • (一)为什么要选择C++
  • (已解决)vscode如何选择python解释器
  • (原創) 如何刪除Windows Live Writer留在本機的文章? (Web) (Windows Live Writer)
  • .MSSQLSERVER 导入导出 命令集--堪称经典,值得借鉴!
  • .NET 4.0中的泛型协变和反变
  • .NET IoC 容器(三)Autofac
  • .NET编程——利用C#调用海康机器人工业相机SDK实现回调取图与软触发取图【含免费源码】