axios封装

Posted llllpzyy

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了axios封装相关的知识,希望对你有一定的参考价值。

封装axios.js

import axios from ‘axios‘

axios.defaults.widthCredentials = true;
axios.defaults.crossDomain = true;
axios.defaults.timeout = 1000;
axios.defaults.baseURL =‘url‘;
axios.defaults.headers.post[‘Content-Type‘] = ‘applicantion/json;charset=UTF-8‘;
axios.defaults.headers.get[‘Content-Type‘] = ‘application/json;charset=UTF-8‘;
axios.defaults.headers.common[‘Authorization‘] = ‘‘+Cookies.get(tokenKey); // 设置请求头为 Authorization
//加载动画显示
//创建axios实例
let util = {};
util.ajax = axios.create({});
//request 拦截器
util.ajax.interceptors.request.use( config =>{
    return config;
},error => {
    return Promise.reject(error);
})
// response 拦截器
util.ajax.interceptors.response.use( response =>{
    if(laoding){
        loading.close();
    }
    if(response.data.code === ‘401‘){
        console.log(‘response----------‘, response);
        //全局登陆过滤,当判读token失效或者没有登录时 返回登陆页面
        return false;
    }
    return Promise.resolve(response);
}, error =>{
    loading.close();
    return Promise.reject(error)
})
export default {
    /*
   * get方法,对应get请求
   * @param {String} url [请求的url地址]
   * @param {Object} params [请求时携带的参数]
   */
   get (url, params) {
       return new Promise( (resolve, reject) =>{
           util.ajax.get(url, {params: params},
           {
                headers: {
                    ‘Authorization‘: ‘‘ + getToken(‘Token‘),
                    ‘token‘: getToken(‘Token‘)
                }
           }).then(res => {
               resolve(res)
           }).catch(err => {
               reject(err)
           })
       })
   },
    /**
   * post方法,对应post请求
   * @param {String} url [请求的url地址]
   * @param {Object} params [请求时携带的参数]
   */
   post (url, params) {
    return new Promise((resolve, reject) => {
      util.ajax.post(url, params,
        {
          headers: {
            ‘Authorization‘: ‘‘ + getToken(‘Token‘),
          }
        })
        .then(res => {
          resolve(res.data)
        })
        .catch(err => {
          reject(err)
        })
    })
  }
}

引用axios.js,定义接口

import request from ‘@/api/axios‘

export function login (params) {
  return request.post(‘/user/login‘, params)
}
export function getUserAll (params) {
  return request.get(‘/user/getall‘, params)
}

页面使用方法

login(userinfo).then(res => {
    console.log(res)
    setToken(‘Token‘, res.token)
    this.$router.push({path: ‘/‘})
})

 

以上是关于axios封装的主要内容,如果未能解决你的问题,请参考以下文章

VSCode自定义代码片段14——Vue的axios网络请求封装

回归 | js实用代码片段的封装与总结(持续更新中...)

项目集成element-plus和axios

vue_cli封装axios--完整代码

vue axios 封装解析

axios简单封装