axios 封装

时间:2020-8-22 作者:admin

axios 请求封装

1.在开发的过程中,我们总是要进行 axios 请求,下面是我对 axios 的封装,希望对你有所帮助。
2.在和 main.js 同级目录下新建一个 http.js ,代码如下:

import axios from 'axios'
import qs from 'qs'
axios.defaults.timeout = 5000;                        //响应时间
axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8';        //配置请求头
axios.defaults.baseURL = 'http://192.168.1.16:3000/';   //配置接口地址

//POST传参序列化(添加请求拦截器)
axios.interceptors.request.use((config) => {
  //在发送请求之前做某件事
  if(config.method  === 'post'){
    config.data = qs.stringify(config.data);
  }
  return config;
},(error) =>{
  console.log('错误的传参')
  return Promise.reject(error);
});

//返回状态判断(添加响应拦截器)
axios.interceptors.response.use((res) =>{
  //对响应数据做些事
  if(!res.data.success){
    return Promise.resolve(res);
  }
  return res;
}, (error) => {
  console.log('网络异常')
  return Promise.reject(error);
});

//返回一个Promise(发送post请求)
export function fetchPost(url,params) {
  return new Promise((resolve, reject) => {
    axios.post(url,params)
      .then(response => {
        resolve(response);
      }, err => {
        reject(err);
      })
      .catch((error) => {
        reject(error)
      })
  })
}
// 返回一个Promise(发送get请求)
export function fetchGet(url,param) {
  return new Promise((resolve, reject) => {
    axios.get(url,{params:param})
      .then(response => {
        resolve(response)
      }, err => {
        reject(err)
      })
      .catch((error) => {
        reject(error)
      })
  })
}
export default {
  fetchPost,
  fetchGet,
}

3.在vue组件中添加如下代码:

mounted() {
          var aa={
            aa:"陈风",
            pass:"100"
          };
          var _this=this;
        chenhttp.fetchPost('/feng',aa ).then((data) => {
          console.log(data);
          _this.chenres=data;
        }).catch(err=>{
            console.log(err)
          }
        )


        setTimeout(function () {
          console.log("++++++++++++");
          console.log(_this.chenres);

        },80)
      }
//注意: chenres 是在 return 下面定义的

4.刷新浏览器你就会看到对应的后台输出结果了,是不是很简单!让我们一起努力走向巅峰!

声明:本文内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎进行举报,并提供相关证据,工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。