這次帶給大家vue使用axios與封裝,vue使用axios與封裝的注意事項有哪些,以下就是實戰案例,一起來看一下。
首先上需求
#
1.需要封裝全域統一處理
4.除了登入介面token帶入頭部
5.登入時候把使用者資訊自動存到vuex裡面
<strong>/**<br> * User: sheyude<br> * Time: 下午 13:15<br> *<br> */<br>import axios from 'axios';<br>// 导入<a href="http://www.php.cn/code/10545.html" target="_blank">配置文件</a> 配置文件就导入的请求的前缀地址<br>import {defaults} from '@/config/'<br>import storage from './storage'<br>// 这是一个饿了么的弹框<br>import { Message } from 'element-ui';<br>//<a href="http://www.php.cn/code/8586.html" target="_blank">路由</a>配置<br>import router from '@/router'<br>/**<br> * 封装的全局ajax请求<br> */<br>class Axios{<br> constructor (){<br> this.init();<br> };<br> /**<br> * 初始化<br> */<br> init(){<br> axios.defaults.baseURL = defaults.baseURL;<br> };<br> _setUserInfo(data){<br> // 把请求的数据存入vuex<br> store.commit('setUserInfo',data);<br> /**<br> * 判断是否是登录<br> * @param url<br> * @<a href="http://www.php.cn/wiki/135.html" target="_blank">return</a>s {boolean}<br> * @private<br> */<br> _isLogin(url){<br> if(url != '/app/login'){<br> axios.defaults.headers = {'x-token': store.state.user.user.token.token};<br> return false;<br> }else{<br> return true;<br> }<br> }<br> <br> /**<br> * 判断是否返回数据<br> * @param data 接收到的数据<br> * @returns {boolean}<br> * @private<br> */<br> _isStatus(data){<br> if(data.code == 100){<br> router.push('/login');<br> Message.error(data.message || '请重新登录!');<br> <br> return false<br> }else{<br> return true<br> }<br> }<br> /**<br> * 全局<a href="http://www.php.cn/code/4817.html" target="_blank">错误处理</a><br> * @param data 传入错误的数据<br> * @private<br> */<br> _error(data){<br> console.log(data)<br> Message.error('网络错误!');<br> }<br> <br> /**<br> * GET 请求 {es6解构赋值}<br> * @param type 包含url信息<br> * @param data 需要发送的参数<br> * @returns {Promise}<br> * @constructor<br> */<br> HttpGet({url},data) {<br> console.log(data)<br> // 创建一个promise对象<br> this._isLogin(url)<br> this.promise = new Promise((resolve, reject)=> {<br> axios.get(url,{params:data})<br> .then((data) => {<br> // console.log(data)<br> if(this._isStatus(data.data)){<br> resolve(data.data);<br> }<br> })<br> .catch((data) =>{<br> this._error(data);<br> })<br> })<br> return this.promise;<br> };<br> /**<br> * POST 请求<br> * @param type <a href="http://www.php.cn/wiki/60.html" target="_blank">Object</a> 包含url信息<br> * @param data Object 需要发送的参数<br> * @param urlData Object 需要拼接到地址栏的参数<br> * @returns {Promise}<br> * @constructor<br> */<br> HttpPost({url},Data,urlData){<br> <br> // 判断是否加头部<br> this._isLogin(url);<br> // 创建一个promise对象<br> this.promise = new Promise((resolve, reject)=> {<br> for(const item in urlData){<br> url += '/' + urlData[item];<br> };<br> axios.post(url,Data)<br> .then((data) => {<br> <br> // 是否请求成功<br> if(this._isStatus(data.data)){<br> // 是否需要存数据<br> if(this._isLogin(url)){<br> this._setUserInfo(data.data)<br> };<br> resolve(data.data)<br> };<br> })<br> .catch((data) =>{<br> this._error(data);<br> })<br> })<br> return this.promise;<br> };<br>};<br>export default new Axios();</strong>
呼叫方式
this.$axios.HttpPost(this.audit.auditGet,this.params) .then((data) => { this.pageData = data.data })
接收2個參數
# 1 url 位址
2 需要傳遞的參數
相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!
推薦閱讀:
JS的類型怎麼轉換#JS陣列刪除指定元素JS中FileReader實作圖片上傳預覽以上是vue使用axios與封裝的詳細內容。更多資訊請關注PHP中文網其他相關文章!