您现在的位置是:首页 > 网站制作 > vue.js心得vue.js心得
封装vue axios
蒙xs2020-09-30【vue.js心得】人已围观
简介npm install axios; // 安装axios
封装axios
在src目录下创建reques
下面创建api.js,http.js
api.js 放接口
http 放封装方法
http.js
在组件调用方法
GET
// 在http.js中引入axios import axios from 'axios'; // 引入axios import QS from 'qs'; // 引入qs模块,用来序列化post类型的数据,后面会提到 // 环境的切换 if (process.env.NODE_ENV == 'development') { //开发环境 // axios.defaults.baseURL = 'https://cnodejs.org/api/v1'; axios.defaults.baseURL = 'http://api.menghn.com/api/'; } else if (process.env.NODE_ENV == 'debug') { console.log('1') axios.defaults.baseURL = 'https://api.uomg.com/api/'; } else if (process.env.NODE_ENV == 'production') { //生产环境 axios.defaults.baseURL = 'https://api.uomg.com/api/'; } axios.defaults.timeout = 10000; axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8'; // 先导入vuex,因为我们要使用到里面的状态对象 // vuex的路径根据自己的路径去写 import store from '@/store/index'; // 请求拦截器 axios.interceptors.request.use( config => { console.log('这里是请求拦截器') // 每次发送请求之前判断vuex中是否存在token // 如果存在,则统一在http请求的header都加上token,这样后台根据token判断你的登录情况 // 即使本地存在token,也有可能token是过期的,所以在响应拦截器中要对返回状态进行判断 const token = store.state.token; token && (config.headers.Authorization = token); return config; }, error => { return Promise.error(error); } ) // http响应拦截器 // 响应拦截器 axios.interceptors.response.use( response => { // 如果返回的状态码为200,说明接口请求成功,可以正常拿到数据 // 否则的话抛出错误 console.log('响应拦截器'); if (response.status === 200) { return Promise.resolve(response); } else { return Promise.reject(response); } }, // 服务器状态码不是2开头的的情况 // 这里可以跟你们的后台开发人员协商好统一的错误状态码 // 然后根据返回的状态码进行一些操作,例如登录过期提示,错误提示等等 // 下面列举几个常见的操作,其他需求可自行扩展 error => { if (error.response.status) { switch (error.response.status) { // 401: 未登录 // 未登录则跳转登录页面,并携带当前页面的路径 // 在登录成功后返回当前页面,这一步需要在登录页操作。 case 401: //这里跳转页面 break; // 403 token过期 // 登录过期对用户进行提示 // 清除本地token和清空vuex中token对象 // 跳转登录页面 case 403: alert('登录过期,请重新登录') // 清除token localStorage.removeItem('token'); store.commit('loginSuccess', null); // 跳转登录页面,并将要浏览的页面fullPath传过去,登录成功后跳转需要访问的页面 setTimeout(() => { //这里跳转页面 }, 1000); break; // 404请求不存在 case 404: alert('网络请求不存在') break; // 其他错误,直接抛出错误提示 default: alert(error.response.data.message) } return Promise.reject(error.response); } } ); /** * get方法,对应get请求 * @param {String} url [请求的url地址] * @param {Object} params [请求时携带的参数] */ export function get(url, params) { return new Promise((resolve, reject) => { axios.get(url, { params: params }).then(res => { resolve(res.data); }).catch(err => { reject(err.data) }) }); } /** * post方法,对应post请求 * @param {String} url [请求的url地址] * @param {Object} params [请求时携带的参数] */ export function post(url, params) { return new Promise((resolve, reject) => { axios.post(url, QS.stringify(params)).then(res => { resolve(res.data); }).catch(err => { reject(err.data) }) }); } api.js
/**
* api接口统一管理
*/
import {get, post} from './http'
export const apiAddress = p => get('topics', p);
export const apiPost = p => post('http://api.menghn.com/api/captcha/captcha', p);
在组件调用方法
GET
// 调用api GIT接口,并且提供了1个参数
apiAddress({
page: 20
}).then(res => {
console.log(res);
// 获取数据成功后的其他操作
})
POST
// 调用api POST接口,并且提供了1个参数
apiPost({
id: '14s5se'
}).then(res => {
console.log(res);
})
来源参考https://juejin.im/post/6844903652881072141
Tags:
很赞哦! ()
上一篇:vue 跳转路由参数加密
下一篇:vue安装切换淘宝镜像