vue axios 二次封装

因项目需要使用了Vue,搭建框架时从vue-resource换成官方推荐的axios并进行封装。封装可统一处理错误码提示、接口全报文加解密。同时对接口进行统一归类,便于后期接口升级或更名维护。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这段时间告诉项目需要,用到了vue。 刚开始搭框架的时候用的是vue-resource后面看到官方推荐axios就换过来了 顺便封装了一下

定义公共参数与引入组件:

import axios from 'axios'
import qs from 'qs'

axios.interceptors.request.use(config => {
   //显示loading
  return config
}, error => {
  return Promise.reject(error)
})


axios.interceptors.response.use(response => {
  return response
}, error => {
  return Promise.resolve(error.response)
})

function errorState(response) {
    //隐藏loading
  console.log(response)
  // 如果http状态码正常,则直接返回数据
  if (response && (response.status === 200 || response.status === 304 || response.status === 400)) {
    return response
      // 如果不需要除了data之外的数据,可以直接 return response.data
  }else{
    Vue.prototype.$msg.alert.show({
            title: '提示',
            content: '网络异常'
    })
  }
  
}

function successState(res) {
   //隐藏loading
  //统一判断后端返回的错误码
  if(res.data.errCode == '000002'){
       Vue.prototype.$msg.alert.show({
            title: '提示',
            content: res.data.errDesc||'网络异常',
            onShow () {
            },
            onHide () {
              console.log('确定')
            }
       })
  }else if(res.data.errCode != '000002'&&res.data.errCode != '000000') {
      Vue.prototype.$msg.alert.show({
            title: '提示',
            content: res.data.errDesc||'网络异常',
            onShow () {

            },
            onHide () {
              console.log('确定')
            }
       })
  }
}
const httpServer = (opts, data) => {

    let Public = { //公共参数
      'srAppid': ""
    }

    let httpDefaultOpts = { //http默认配置
          method:opts.method,
          baseURL,
          url: opts.url,
          timeout: 10000,
          params:Object.assign(Public, data),
          data:qs.stringify(Object.assign(Public, data)),
          headers: opts.method=='get'?{
            'X-Requested-With': 'XMLHttpRequest',
            "Accept": "application/json",
            "Content-Type": "application/json; charset=UTF-8"
          }:{
            'X-Requested-With': 'XMLHttpRequest',
            'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'
          }
    }

    if(opts.method=='get'){
      delete httpDefaultOpts.data
    }else{
      delete httpDefaultOpts.params
    }
    
    let promise = new Promise(function(resolve, reject) {
      axios(httpDefaultOpts).then(
        (res) => {
          successState(res)
          resolve(res)
        }
      ).catch(
        (response) => {
          errorState(response)
          reject(response)
        }
      )

    })
  return promise
}

export default httpServer
复制代码

封装理由:

1、可以和后端商量好错误码在这统一提示统一处理,省去不必要的麻烦

2、如果做接口全报文加解密都可以在此处理

接口统一归类:

const serviceModule = {
  getLocation: {
    url: ' service/location/transfor',
    method: 'get'
  }
}
const ApiSetting = {...serviceModule }

export default ApiSetting
复制代码

归类好处:

1、后期接口升级或者接口名更改便于维护

http调用:


<script>
import http from "../../lib/http.js";
import ApiSetting from "../../lib/ApiSetting.js";
export default {
  created: function() {
    http(ApiSetting.getLocation,{"srChannel": "h5",})
    .then((res)=>{
      console.log(res)
    },(error)=>{
      console.log(error)	
    })
   },
  methods: {
  
  }
}
</script>
复制代码

转载于:https://juejin.im/post/5b8371e6f265da43516a2fbe

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值