axios 如何正确进行封装?

第一步:npm install axios --save安装axios

第二步

第二步:在src目录下新建一个request文件夹,并创健一个http.js和api.js文件,其中api.js是管理我们接口的文件。

以下是http.js的配置

import axios from 'axios'
import { Toast } from 'vant'//这里我用的是vant组件的弹窗

//默认请求地址
axios.defaults.baseURL = 'http://shopping.com/'

//请求超时时间
axios.defaults.timeout = 10000

//请求头
axios.defaults.headers.post['Content=Type']='application/json'

//请求拦截
axios.interceptors.request.use(
    config => {
        return config
    },
    error => {
        return Promise.error(error)
    }
)

//响应拦截器
axios.interceptors.response.use(
    response => {
        // 如果返回的状态码为200,说明接口请求成功,可以正常拿到数据 
        // 否则的话抛出错误
        if(response.status === 200){
            return Promise.resolve(response)
        } else {
            return Promise.reject(response)
        }
    },
    // 服务器状态码不是2开头的的情况 
    // 这里可以跟你们的后台开发人员协商好统一的错误状态码  
    // 然后根据返回的状态码进行一些操作,例如登录过期提示,错误提示等等
    error => {
        if(error.response.status){
            switch (error.response.status){
                // 401: 未登录  
                // 未登录则跳转登录页面,并携带当前页面的路径  
                // 在登录成功后返回当前页面,这一步需要在登录页操作
                //case 401:
                case 404:
                    Toast({
                        message:'网络请求不存在',
                        duration:1500,
                        forbidClick:true
                    })
                    break
                case 400:
                    Toast({
                        message:'服务器繁忙',
                        duration:1500,
                        forbidClick:true
                    })
                    break
                default:
                    Toast({
                        message:'其它提示',
                        duration:1500,
                        forbidClick:true
                    })  
            }
            return Promise.reject(error.response)
        }
    }
)
/** 
 * get方法,对应get请求
 * @param {String} url [请求的url地址] 
 * @param {Object} params [请求时携带的参数] 
 */

 export function get(url,params=''){
     return new Promise((resolve,reject)=>{
         axios.get(url,{
             params
         }).then(res=>{
             resolve(res.data)
         }).catch(err => {
             reject(err.data)
         })
     })
 }

 /**  
  * post方法,对应post请求  
  * @param {String} url [请求的url地址]  
  * @param {Object} params [请求时携带的参数]  
  */

 export function post(url,params){
    return new Promise((resolve,reject)=>{
        axios.post(url,{
            params
        }).then(res=>{
            resolve(res.data)
        }).catch(err => {
            reject(err.data)
        })
    })
}

具体配置请参考axios文档

以下是api.js

import { get,post } from './http'
//banner接口
export const apiBanner = banner => get('api/v1/banner',banner)

//boutique接口
export const apiBoutique = boutique => get('api/v1/boutique',boutique)

//special接口
export const apiSpecial = special => get('api/v1/special',special)
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值