axios网络请求封装

一、

//network/request.js
import axios from "axios";
export function request(config,success,failure){
  //1.创建axios的实例
  const instance = axios.create({
    baseURL:'http://123.337.33.33:8000',
    timeout:5000
  })
  //发送真正的网络请求
  instance(config)
    .then(res =>{
      success(res)
    })
    .catch(err =>{
      failure(err)
    })
}

//main.js
import {request} from "./network/request";
request({
  url:'/home/multidata'
},res =>{
    console.log(res);
  },err => {
    console.log(err);
  }
)

二、

//network/request.js
export function request(config){
  //1.创建axios的实例
  const instance = axios.create({
    baseURL:'http://123.337.33.33:8000',
    timeout:5000
  })
  //发送真正的网络请求
  instance(config.baseConfig)
    .then(res =>{
      config.success(res)
    })
    .catch(err =>{
      config.failure(err)
    })
}

//main.js
request({
baseConfig:{
  url:'/home/multidata'
},
success: res=>{
  console.log(res);
},
  failure:err => {
    console.log(err);
  }
})

三、

//network/request.js
export function request(config){
 return new Promise((resolve,reject)=>{
   //1.创建axios的实例
   const instance = axios.create({
     baseURL:'http://123.337.33.33:8000',
     timeout:5000
   })
   //发送真正的网络请求
   instance(config)
     .then(res =>{
      resolve(res)
     })
     .catch(err =>{
       reject(err)
     })
 })
}

//main.js
request({
  url:'/home/multidata'
}).then(res =>{
  console.log(res);
}).catch(err => {
  console.log(err);
})

四、

看源码可以知道instance(config)返回的就是Promise,所以还可以这样写
在这里插入图片描述在这里插入图片描述

//network/request.js
export function request(config){
    //1.创建axios的实例
    const instance = axios.create({
      baseURL:'http://123.337.33.33:8000',
      timeout:5000
    })
    //3.发送真正的网络请求  instance返回的就是一个Promise
  return instance(config)
}

//main.js
request({
  url:'/home/multidata'
}).then(res =>{
  console.log(res);
}).catch(err => {
  console.log(err);
})
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值