axios封装 vue

9 篇文章 0 订阅
4 篇文章 0 订阅

引入axios封装

import axios from "axios";

// axios封装请求方法
// axios配置
const config = {
  baseURL: "",
  headers: {
    "Content-type": "application/json",
  },
  timeout: 30000,
};
const instance = axios.create(config);

// 请求前做拦截,用于判断
const requestInterceptor = instance.interceptors.request.use(
  (config) => {
    // 拦截修改config
    // 返回到请求中配置
    // if (!config.headers.token) {
    //   // headers没有token令牌执行
    //   config.headers.token = "no";
    // }
    return config;
  },
  (error) => {
    // 立即执行失败的reject方法
    return Promise.reject(error);
  }
);
// 响应后做拦截,用于修改响应数据
const responseInterceptor = instance.interceptors.response.use(
  (response) => {
    // 对响应数据做点什么
    // console.log('对响应数据做点什么',response)
    return response;
  },
  (error) => {
    // 立即执行响应的reject方法
    return Promise.reject(error);
  }
);
// 移除拦截器
// interceptors.request.eject(requestInterceptor);
// interceptors.request.eject(responseInterceptor);

封装post和get方法:1

// 和 promise + generator 一起使用的get封装
const get = (url, data, handle, errorHandle) => {
  instance
    .get(url, { params: data })
    .then((res) => {
      let result = res.data;
      console.log("请求:", res);
      return result
      if (handle || typeof handle == "function") handle(result);
    })
    .catch((error) => {
      if (errorHandle || typeof errorHandle == "function") errorHandle(error);
    });
};
const post = (url, data, handle, errorHandle) => {
  instance
    .post(url, data)
    .then((res) => {
      let result = res.data;
      if (handle || typeof handle == "function") handle(result);
    })
    .catch((error) => {
      if (errorHandle || typeof errorHandle == "function") errorHandle(error);
    });
};

export default { get, post}

封装post和get方法:2(链式结构)

const get= (url, data = {}) => {
  return instance.get(url, {
    params: data
  });
}

const post = (url, data = {}) => {
  return instance.post(url, data);
}
export default { get, post}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值