简单的封装axios 不包含状态码和提示

复杂封装,包含提示和状态码的,点击这里查看

以下是简单封装axios的request.js文件:

import axios from 'axios'
import router from './../router'
import { Message } from 'element-ui'

// 设置axios全局默认的BASE-URL, 只要设置了全局的默认base_url,以后的请求会自动拼接上base_url
// -------------------------------注意改成自己的公共url------------------------------------
axios.defaults.baseURL = 'http://192.168.1.194/gateway'
axios.defaults.timeout = 10000

// 配置axios的请求拦截器-(每次在请求头上携带后台分配的token-后台判断token是否有效等问题)
axios.interceptors.request.use(config => {
  // 在发送请求之前做些什么
  // console.log('请求到了哟', config.headers.Authorization)

  // 如果有其他的特殊配置 只需要判断config参数 设置即可

  // 标识系统为AJAX请求
  config.headers['X-Requested-With'] = 'XMLHttpRequest'

  // 统一的给config设置 token-------------------------------注意获取方法------------------------------------
  //   config.headers.Authorization = JSON.parse(localStorage.getItem('token'))
  config.headers['Token'] = '3d2eec53c6f74f43a85e8df083d9bf84'
  return config
}, error => {
  // 对请求错误做些什么
  return Promise.reject(error)
}
)

// 响应拦截器 与后端定义状态是100时候是错误 跳转到登录界面
axios.interceptors.response.use(response => {
  // 对响应数据做点什么
  console.log('接口success', response)

  // 当返回信息为未登录或者登录失效的时候重定向为登录页面
  if (
    response.data.status == 100 ||
        response.data.message == '用户未登录或登录超时,请登录!'
  ) {
    localStorage.removeItem('token')
    router.push({
      path: '/login',
      querry: { } // 从哪个页面跳转
    })
    Message.warning(response.data.message)
  }
  return response.data
}, error => {
  console.log('接口error', error)
  // 对响应错误做点什么
  return Promise.reject(error)
}
)

const $http = {}

$http.get = function(url, data, config) {
  //  这一步把api方法里的  地址 参数 配置传入进来 配置到config 然后调用上面封装的axios
  config = config || {}
  config.url = url
  config.method = 'get'
  config.params = data
  return axios.request(config)
}

$http.delete = function(url, data, config) {
  config = config || {}
  config.url = url
  config.method = 'delete'
  config.params = data
  return axios.request(config)
}

$http.post = function(url, data, config) {
  config = config || {}
  config.url = url
  config.method = 'post'
  config.data = data
  return axios.request(config)
}

$http.put = function(url, data, config) {
  config = config || {}
  config.url = url
  config.method = 'put'
  config.data = data
  return axios.request(config)
}

export { axios, $http }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以给你提供一个基本的示例代码,你可以根据自己的需求进行修改和扩展: ```javascript import axios from 'axios'; const BASE_URL = 'https://api.example.com'; const axiosInstance = axios.create({ baseURL: BASE_URL, timeout: 5000, // 超时时间 headers: { 'Content-Type': 'application/json' } }); axiosInstance.interceptors.request.use( config => { // 在请求发送之前可以进行一些处理,如添加 token // config.headers.Authorization = 'Bearer ' + token; return config; }, error => { return Promise.reject(error); } ); axiosInstance.interceptors.response.use( response => { // 在响应返回之前可以进行一些处理 return response.data; }, error => { // 处理错误响应 if (error.response) { // 根据状态码进行相应的操作,如重定向、提示错误信息等 switch (error.response.status) { case 401: console.log('未授权'); break; case 404: console.log('请求的资源不存在'); break; default: console.log('请求出错'); break; } } return Promise.reject(error); } ); export default axiosInstance; ``` 这个示例代码中,我们创建了一个 axios 实例,设置了请求的基本 URL 和超时时间,还添加了请求和响应的拦截器。在请求拦截器中,我们可以在请求发送之前进行一些处理,比如添加 token 等;在响应拦截器中,我们可以在响应返回之前进行一些处理,比如进行数据格式转换等。同时,我们还可以根据不同的状态码进行相应的处理。最后,我们将封装好的 axios 实例导出,可以在其他地方直接使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值