封装axios

摘要:创建一个server目录,在该目录下创建index.js文件,配置axios:使用create方法创建axios实例,封装请求方法:创建一个api.js文件

1、创建一个server目录,在该目录下创建index.js文件


2、配置axios:

import axios from 'axios'
//使用create方法创建axios实例
export const Service = axios.create({
  timeout: 6000, // 请求超时时间
  baseURL: process.env.BASE_API,// 配置在环境变量中
  headers: {
    'Content-Type': 'application/json;charset=UTF-8'
  }
})
// 添加请求拦截器
Service.interceptors.request.use(
config => {
  // 这里可以引入loading 或者 执行一个回调方法
  return config
},
error => {
return Promise.reject(error)
 }
)
// 添加响应拦截器
Service.interceptors.response.use(response => {
  // console.log(response)
  let res = response.data
  return res 
}, error => {
  console.log(error)
  const msg = error.message!== undefined ? error.message : ''
  return Promise.reject(error)
})


3、封装请求方法:

创建一个api.js文件

inport Serviceform 'server/index.js'
export function post(params) {
  return Service({
    url: 'login',
    methed:'post',
    params:params
  })
}
export function get(params) {
  return Service({
    url: 'getLists',
    method: 'get',
    params:params
  })
}
export function update(params) {
  return Service({
    url: 'update',
    methed:'put',
    params
  })
}
export function delete(params) {
  return Service({
    url: 'delete',
    methed:'delete',
    params:params
  })
}

本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!

链接: https://shenqiku.cn/article/FLY_6426