认识Axios

axios中文网

一. 为什么会诞生Axios

  1. 最初浏览器页面向服务器请求数据时,返回的是整个页面,整个页面都会刷新
  2. ajax的出现,它可以在页面无刷新的情况下请求数据
  3. 原生的XMLHttpRequest,jQuery封装的ajax,以及axios都可以实现异步的网络请求
  4. axios(相比于原生的XMLHttpRequest对象)简单易用,(相比于jQuery)axios包尺寸小且提供了易于扩展的接口,是专注于网络请求的库
  5. axios本质上是XMLHttpRequest的封装

二. Axios是什么

  • axios是一个基于Promise的网络请求库,可以用于浏览器和node.js
  • 简单来说就是可以发送get、post等请求
  • vue、react等框架的出现,促使axios轻量级库的出现。因为vue、react等不需要操作dom,所以不需要引入jquery.js了

三. axios与ajax的区别

理论区别:

  • axios是通过Promise实现对ajax的封装,就像jQuery对ajax的封装一样。ajax实现了页面局部的刷新,axios实现了对ajax的封装
  • axios是ajax,ajax不止axios,即axios是ajax的衍生

逻辑区别:

  • ajax 本身是一个针对MVC的编程
  • axios符合现在前端MVVM的浪潮

axios的特点:

  • 从浏览器创建XMLHttpRequest
  • 从node.js创建http请求
  • 支持Promise API
  • 拦截请求和响应
  • 转换请求和响应数据
  • 取消请求
  • 自动转换JSON数据
  • 客户端支持防御XSRF

四. axios请求的五种方式(get,post,put,patch,delete)

注:使用axios记得先安装它的依赖,并导入,此处省略

  • get:获取数据
  • post:提交数据(表单提交+文件上传)
  • put:更新数据(所有数据推送到后端)
  • patch:更新数据(只将更新的数据推送到后端)
  • delete:删除数据
javascript 复制代码
// params 是将与请求一起发送的url参数,对应后台中的query
// data 是作为请求主体被发送的数据,对应后台中的body
axios.request(config)
axios.get(url[, config])  // 只支持 params 传参
axios.delete(url[, config])  // 只支持 params传参
axios.head(url[, config]) // 只支持 params传参
axios.post(url[, data[, config]]) // 同时支持  data 和 params
axios.put(url[, data[, config]]) // 同时支持  data 和 params
axios.patch(url[, data[, config]]) // 同时支持  data 和 params

使用方法:

1. get方法

javascript 复制代码
<script>
    import axios from 'axios'
    export default {
        mounted () {
            axios.get('接口地址', {params: {}}).then((res) => {})
        }
    }
</script>

2. post方法

javascript 复制代码
<script>
    import axios from 'axios'
    export default {
        mounted () {
            // 1.【参数为application/json请求方式】
            axios.post('接口地址', {}).then((res) => {})

            // 2.【参数为form-data请求方式的表单提交(图片上传/文件上传)】
            let data = { id: 12 }
            let formData = new formData()
            for (let key in data) {
                formData.append(key, data[key])
            }
            axios.post('接口地址', formData).then((res) => {})
        }
    }
</script>

3. put方法

javascript 复制代码
<script>
    import axios from 'axios'
    export default {
        mounted () {
            axios.put('接口地址', {}).then((res) => {})
        }
    }
</script>

4. patch方法

javascript 复制代码
<script>
    import axios from 'axios'
    export default {
        mounted () {
            axios.patch('接口地址', {}).then((res) => {})
        }
    }
</script>

5. delete方法

javascript 复制代码
<script>
    import axios from 'axios'
    export default {
        mounted () {
            // 写法一
            axios.delete('接口地址', { params: {} }).then((res) => {})

            // 写法二
            axios.delete('接口地址', { data: {} }).then((res) => {})
        }
    }
</script>

五. axios拦截器的介绍

1. axios拦截器的原理:

网络请求 ------> axios ------> 请求拦截器 ------> 服务器

------> 响应拦截器 ------> 服务器

2. 请求拦截器:主要处理token的统一注入问题

javascript 复制代码
import axios from 'axios';
const axiosRequest = axios.create(); // 创建axios实例

axiosRequest.interceptors.request.use(config => {
        // 有token修改token,没有token跳转登录
        if (store.getters.getToken !== '') {
            // 让每个请求携带token-- ['X-Token']为自定义key 请根据实际情况自行修改
            if(!config.headers['Authorization']){
              config.headers['Authorization'] = store.getters.getToken; // getToken();
            }
        } else {
            if (config.url.charAt('/login?') == -1) {
              window.location = '/login';
            }
        }                
        return config
    }, error => {
    return Promise.reject(error)
})

3. 响应拦截器:主要处理返回的数据异常和数据结构的问题

javascript 复制代码
import axios from 'axios';
const axiosRequest = axios.create(); // 创建axios实例

axiosRequest.interceptors.response.use(response => {
    if (response && response.data && response.data.code == '401') {
        store.dispatch("setToken", "");
        if (messagetimeout) {
          clearTimeout(messagetimeout)
          messagetimeout = null
        }
        messagetimeout = setTimeout(function () {
          this.$message({
            type: 'error',
            message: '认证失效,请重新登录!',
            duration: 1000,
            onClose: function () {}
          })
          setTimeout(() => {
            let routeData = router.resolve({
              path: '/login',
            })
            location.href= routeData.href;
          }, 500)
        }, 500)
        return Promise.reject(response.data)
      }
    if (response && response.data && response.data.code == '20007') {                        
        this.$message({
          type: 'error',
          message: '此用户已在其他地方登陆! ',
          duration: 1000,
          onClose: function () {
            window.location = 'login';
          }
        })
        return Promise.reject(response.data)
      }
      if (response && response.data && !response.data.success && !isMobile) {
        if (typeof response.data == 'object' && !(response.data instanceof Blob)) {
          this.$message({
            type: 'error',
            message: response.data.message
          })
        }
      }
},async error => {
    // error 有response对象 config
    if (error.response && error.response.data && error.response.data.code === 10002) {
        // 后端告诉前端token超时了
        await store.dispatch('user/lgout') // 调用登出action
        router.push('/login') // 跳到登录页
    }
    this.$message.error(error.message) // 提示错误
    return Promise.reject(error) // 传入一个错误的对象  就认为promise执行链 进入了catch  
})

六. axios的封装

相关推荐
伍哥的传说10 小时前
Vue3 响应式翻牌抽奖游戏
javascript·vue.js·游戏·前端框架·vue·交互
胡斌附体1 天前
vue父子组件通信的使用, 跟新v-model
vue·v-model·使用场景·emit·子父组件通信·change事件
「、皓子~2 天前
AI创作系列(2):UniApp跨端开发实战 - 海狸IM移动端完全由AI编写
开发语言·人工智能·uni-app·开源·vue·开源软件·ai编程
sunshine_程序媛2 天前
在Vue2项目中引入ElementUI详细步骤
前端·ui·elementui·前端框架·vue
努力了吗梁同学2 天前
Nuxt3 中使用 pnpm 安装的 NuxtImg 使用会提示找不到图片
前端·vue·pnpm·nuxt·nuxtimg
sg_knight2 天前
Rollup vs Webpack 深度对比:前端构建工具终极指南
前端·javascript·webpack·node.js·vue·rollup·vite
二倍本贝3 天前
【慧游鲁博】【12】小程序端 · 智能导览对接后端文物图片识别功能
小程序·uni-app·vue·软件工程
小钻风33663 天前
深入浅出掌握 Axios(持续更新)
前端·javascript·axios
bingbingyihao3 天前
UI框架-通知组件
前端·javascript·vue
陌上烟雨寒3 天前
vue手写一个步骤条steps
javascript·css·vue