温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

vue中怎么封装axios请求

发布时间:2021-06-17 15:51:33 来源:亿速云 阅读:252 作者:Leah 栏目:web开发

这篇文章将为大家详细讲解有关vue中怎么封装axios请求,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

axios

Axios 是一个基于 promise 的 HTTP 库,可以用在浏览器和 node.js 中, 也是vue官方推荐使用的http库;封装axios,一方面为了以后维护方便,另一方面也可以对请求进行自定义处理

安装

npm i axios

封装

我把axios请求封装在http.js中,重新把get请求,post请求封装了一次

首先,引入axios

import axios from 'axios'

设置接口请求前缀

一般我们开发都会有开发、测试、生产环境,前缀需要加以区分,我们利用node环境变量来作判断,

if (process.env.NODE_ENV === 'development') {  axios.defaults.baseURL = 'http://dev.xxx.com' } else if (process.env.NODE_ENV === 'production') {  axios.defaults.baseURL = 'http://prod.xxx.com' }

在localhost调试时,直接用开发地址一般都会有跨域的问题,所以我们还需要配置代理

本项目是vue cli3搭建的,代理配置是在vue.config.js文件中:

module.exports = {  devServer: {  proxy: {   '/proxyApi': {   target: 'http://dev.xxx.com',   changeOrigin: true,   pathRewrite: {    '/proxyApi': ''   }   }  }  } }

这样就成功把/proxyApi 指向了 'http://dev.xxx.com',重启服务

修改一下http.js中的配置

if (process.env.NODE_ENV === 'development') {  axios.defaults.baseURL = '/proxyApi' } else if (process.env.NODE_ENV === 'production') {  axios.defaults.baseURL = 'http://prod.xxx.com' }

拦截器

接着设置超时时间和请求头信息

axios.defaults.timeout = 10000 // 请求头信息是为post请求设置 axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8'

axios很好用,其中之一就是它的拦截器十分强大,我们就可以为请求和响应设置拦截器,比如请求拦截器可以在每个请求里加上token,做了统一处理后维护起来也方便,响应拦截器可以在接收到响应后先做一层操作,如根据状态码判断登录状态、授权。

// 请求拦截器 axios.interceptors.request.use(  config => {  // 每次发送请求之前判断是否存在token  // 如果存在,则统一在http请求的header都加上token,这样后台根据token判断你的登录情况,此处token一般是用户完成登录后储存到localstorage里的  token && (config.headers.Authorization = token)  return config  },  error => {  return Promise.error(error)  }) // 响应拦截器 axios.interceptors.response.use(response => {  // 如果返回的状态码为200,说明接口请求成功,可以正常拿到数据  // 否则的话抛出错误  if (response.status === 200) {  if (response.data.code === 511) {   // 未授权调取授权接口  } else if (response.data.code === 510) {   // 未登录跳转登录页  } else {   return Promise.resolve(response)  }  } else {  return Promise.reject(response)  } }, error => {  // 我们可以在这里对异常状态作统一处理  if (error.response.status) {  // 处理请求失败的情况  // 对不同返回码对相应处理  return Promise.reject(error.response)  } })

get post的封装

httpGet: 一个参数是请求的url,一个就携带的请求参数,返回promise对象

// get 请求 export function httpGet({  url,  params = {} }) {  return new Promise((resolve, reject) => {  axios.get(url, {   params  }).then((res) => {   resolve(res.data)  }).catch(err => {   reject(err)  })  }) }

httpPost: 原理和get差不多,需要注意,这里多了个data参数,post请求提交前需要对它进行序列号操作,这里是通过transformRequest做处理;另外两个参数url,params和get请求的一样;

// post请求 export function httpPost({  url,  data = {},  params = {} }) {  return new Promise((resolve, reject) => {  axios({   url,   method: 'post',   transformRequest: [function (data) {   let ret = ''   for (let it in data) {    ret += encodeURIComponent(it) + '=' + encodeURIComponent(data[it]) + '&'   }   return ret   }],   // 发送的数据   data,   // url参数   params  }).then(res => {   resolve(res.data)  })  }) }

如何使用

我把所有的接口调用都在api.js文件中

先引入封装好的方法,再在要调用的接口重新封装成一个方法暴露出去

import { httpGet, httpPost } from './http' export const getorglist = (params = {}) => httpGet({ url: 'apps/api/org/list', params })

在页面中可以这样调用:

// .vue import { getorglist } from '@/assets/js/api' getorglist({ id: 200 }).then(res => {  console.log(res) })

这样可以把api统一管理起来,以后维护修改只需要在api.js文件操作即可。

完整代码
最后贴上完整代码

// http.js import axios from 'axios' // 环境的切换 if (process.env.NODE_ENV === 'development') {  axios.defaults.baseURL = '/proxyApi' } else if (process.env.NODE_ENV === 'production') {  axios.defaults.baseURL = 'http://prod.xxx.com' } // 请求拦截器 axios.interceptors.request.use(  config => {  token && (config.headers.Authorization = token)  return config  },  error => {  return Promise.error(error)  }) axios.defaults.timeout = 10000 axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8' // 响应拦截器 axios.interceptors.response.use(response => {  if (response.status === 200) {  if (response.data.code === 511) {   // 未授权调取授权接口  } else if (response.data.code === 510) {   // 未登录跳转登录页  } else {   return Promise.resolve(response)  }  } else {  return Promise.reject(response)  } }, error => {  // 我们可以在这里对异常状态作统一处理  if (error.response.status) {  // 处理请求失败的情况  // 对不同返回码对相应处理  return Promise.reject(error.response)  } }) // get 请求 export function httpGet({  url,  params = {} }) {  return new Promise((resolve, reject) => {  axios.get(url, {   params  }).then((res) => {   resolve(res.data)  }).catch(err => {   reject(err)  })  }) } // post请求 export function httpPost({  url,  data = {},  params = {} }) {  return new Promise((resolve, reject) => {  axios({   url,   method: 'post',   transformRequest: [function (data) {   let ret = ''   for (let it in data) {    ret += encodeURIComponent(it) + '=' + encodeURIComponent(data[it]) + '&'   }   return ret   }],   // 发送的数据   data,   // url参数   params  }).then(res => {   resolve(res.data)  })  }) }
// api.js import { httpGet, httpPost } from './http' export const getorglist = (params = {}) => httpGet({ url: 'apps/api/org/list', params }) export const save = (data) => {  return httpPost({  url: 'apps/wechat/api/save_member',  data  }) }
// .vue <script> import { getorglist } from '@/assets/js/api' export default {  name: 'upload-card',  data() {},  mounted() {  getorglist({ id: 200 }).then(res => {   // console.log(res)  })  }, } </script>

关于vue中怎么封装axios请求就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI