vue axios 二次封装

这段时间告诉项目需要,用到了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>




  • 3
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
Vue进行axios封装可以提高代码的可维护性和复用性。下面是一种常见的axios封装方式: 1. 首先,安装axios库。可以使用npm或者yarn命令进行安装: ``` npm install axios ``` 2. 创建一个api.js文件,用于封装axios请求。 ```javascript import axios from 'axios'; // 创建一个axios实例 const service = axios.create({ baseURL: 'http://api.example.com', // 设置请求的baseURL timeout: 5000 // 设置请求超时时间 }); // 请求拦截器 service.interceptors.request.use( config => { // 在发送请求之前做一些处理,比如添加token等 return config; }, error => { // 请求错误处理 console.log(error); return Promise.reject(error); } ); // 响应拦截器 service.interceptors.response.use( response => { // 对响应数据做一些处理,比如统一处理错误码等 return response.data; }, error => { // 响应错误处理 console.log(error); return Promise.reject(error); } ); export default service; ``` 3. 在需要发送请求的地方引入api.js文件,并使用封装好的axios实例发送请求。 ```javascript import request from './api.js'; // 发送GET请求 request.get('/user/info', { params: { id: 1 } }) .then(response => { console.log(response); }) .catch(error => { console.log(error); }); // 发送POST请求 request.post('/user/login', { username: 'admin', password: '123456' }) .then(response => { console.log(response); }) .catch(error => { console.log(error); }); ``` 这样,你就完成了Vueaxios封装。通过这种方式,你可以在项目中统一处理请求的配置、拦截器等,提高代码的可维护性和复用性。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值