Heim >Web-Frontend >js-Tutorial >Vue verwendet Axios und Kapselung
Dieses Mal werde ich Ihnen die Verwendung von Axios und Kapselung in Vue vorstellen. Was sind die Vorsichtsmaßnahmen für die Verwendung von Axios und Kapselung in Vue?
Gehen Sie zunächst zu den Anforderungen
1. Globale Aufrufe müssen gekapselt werden
2. Ein Promise-Objekt zurückgeben
3. Fehler global behandeln
4. Zusätzlich zum Anmeldeschnittstellen-Token in den Header einfügen
5. Benutzer automatisch speichern Informationen zum Anmelden bei Inside vuex
Fügen Sie zunächst den Kapselungscode hinzu
<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>
Aufrufmethode
this.$axios.HttpPost(this.audit.auditGet,this.params) .then((data) => { this.pageData = data.data })
Erhält 2 Parameter
1 URL-Adresse
2 Parameter, die übergeben werden müssen
Ich glaube, dass Sie die Methode beherrschen, nachdem Sie den Fall in diesem Artikel gelesen haben. Weitere spannende Informationen finden Sie in anderen verwandten Artikeln zum Thema PHP-Chinesisch Webseite!
Empfohlene Lektüre:
Angegebene Elemente aus dem JS-Array löschen
FileReader in JS implementiert die Bild-Upload-Vorschau
Das obige ist der detaillierte Inhalt vonVue verwendet Axios und Kapselung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!