温馨提示×

温馨提示×

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

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

vue中如何使用axios和封装

发布时间:2021-07-09 10:10:26 来源:亿速云 阅读:566 作者:小新 栏目:web开发

这篇文章给大家分享的是有关vue中如何使用axios和封装的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

vue官方推荐使用 axios发送请求

首先上需求

1.需要封装全局调用
2.返回一个promise对象
3.错误全局统一处理
4.除了登录界面token带入头部
5.登录时候把用户信息自动存到vuex里面

首先上封装代码

import axios from 'axios'; // 导入配置文件 配置文件就导入的请求的前缀地址 import {defaults} from '@/config/' import storage from './storage' // 这是一个饿了么的弹框 import { Message } from 'element-ui'; //路由配置 import router from '@/router' /**  * 封装的全局ajax请求  */ class Axios{   constructor (){     this.init();   };   /**    * 初始化    */   init(){     axios.defaults.baseURL = defaults.baseURL;   };   _setUserInfo(data){     // 把请求的数据存入vuex     store.commit('setUserInfo',data);   }   /**    * 判断是否是登录    * @param url    * @returns {boolean}    * @private    */   _isLogin(url){          if(url != '/app/login'){       axios.defaults.headers = {'x-token': store.state.user.user.token.token};       return false;     }else{       return true;     }   }   /**    * 判断是否返回数据    * @param data 接收到的数据    * @returns {boolean}    * @private    */   _isStatus(data){     if(data.code == 100){       router.push('/login');       Message.error(data.message || '请重新登录!');       return false     }else{       return true     }   }   /**    * 全局错误处理    * @param data 传入错误的数据    * @private    */   _error(data){     console.log(data)     Message.error('网络错误!');   }   /**    * GET 请求 {es6解构赋值}    * @param type 包含url信息    * @param data 需要发送的参数    * @returns {Promise}    * @constructor    */   HttpGet({url},data) {     console.log(data)     // 创建一个promise对象     this._isLogin(url)     this.promise = new Promise((resolve, reject)=> {       axios.get(url,{params:data})         .then((data) => {         // console.log(data)           if(this._isStatus(data.data)){             resolve(data.data);           }         })         .catch((data) =>{           this._error(data);         })     })     return this.promise;   };   /**    * POST 请求    * @param type Object 包含url信息    * @param data Object 需要发送的参数    * @param urlData Object 需要拼接到地址栏的参数    * @returns {Promise}    * @constructor    */   HttpPost({url},Data,urlData){     // 判断是否加头部     this._isLogin(url);     // 创建一个promise对象     this.promise = new Promise((resolve, reject)=> {       for(const item in urlData){         url += '/' + urlData[item];       };       axios.post(url,Data)         .then((data) => {           // 是否请求成功           if(this._isStatus(data.data)){             // 是否需要存数据             if(this._isLogin(url)){               this._setUserInfo(data.data)             };             resolve(data.data)           };         })         .catch((data) =>{           this._error(data);         })     })     return this.promise;   }; }; export default new Axios();

调用方式

this.$axios.HttpPost(this.audit.auditGet,this.params)  .then((data) => {     this.pageData = data.data  })

接收2个参数

1 url 地址
2 需要传递的参数

我目前全局注册了 使用需要挂载到vue原型

感谢各位的阅读!关于“vue中如何使用axios和封装”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

向AI问一下细节

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

AI