vue +axios+promise封裝

import axios? ? ? ? ? ? ? ? from 'axios'

import {Message}from 'element-ui'

import router from '../router/permission'

import Vuefrom 'vue'

import VueCookiesfrom 'vue-cookies'

const moment =require('moment');

const Base64 =require('js-base64').Base64;

// loading框設(shè)置局部刷新,且所有請(qǐng)求完成后關(guān)閉loading框

var loading;

function startLoading() {

loading = Vue.prototype.$loading({

lock:true,

text:"Loading...",

target:document.querySelector('.loading-area')//設(shè)置加載動(dòng)畫區(qū)域

? });

}

function endLoading() {

loading.close();

}

// 聲明一個(gè)對(duì)象用于存儲(chǔ)請(qǐng)求個(gè)數(shù)

var needLoadingRequestCount =0;

function showFullScreenLoading() {

if (needLoadingRequestCount ===0) {

startLoading();

}

needLoadingRequestCount++;

};

function tryHideFullScreenLoading() {

if (needLoadingRequestCount <=0)return;

needLoadingRequestCount--;

if (needLoadingRequestCount ===0) {

endLoading();

}

};

// 請(qǐng)求攔截

axios.interceptors.request.use(config => {

let token ="";

showFullScreenLoading();

if(VueCookies.isKey('userinfo')) {

const USERINFO = VueCookies.get('userinfo');

if(config.method =='get') {

token =Base64.encode(USERINFO.token +'|' +moment().utc().format('YYY-MM-DD HH:mm:ss' +'|' +JSON.stringify(config.params)));

config.params.hospitalId =USERINFO.hospitalId;

}else {

token =Base64.encode(USERINFO.token +'|' +moment().utc().format('YYY-MM-DD HH:mm:ss' +'|' +JSON.stringify(config.data)));

config.data.hospitalId =USERINFO.hospitalId;

}

let TOKENSTART =token.slice(0,10),

TOKENEND =token.slice(10);

token =TOKENEND +TOKENSTART;

config.headers['token'] =token;

}

return config;

}, err => {

tryHideFullScreenLoading();

Message.error({message:'請(qǐng)求超時(shí)!' });

return Promise.resolve(err);

})

// 響應(yīng)攔截

axios.interceptors.response.use(res => {

tryHideFullScreenLoading();

switch(res.data.code) {

case 200:

return res.data.result;

case 401:

router.push('/login');

VueCookies.remove('userinfo');

return Promise.reject(res);

case 201:

Message.error({message: res.data.msg });

return Promise.reject(res);

default :

return Promise.reject(res);

}

}, err => {

tryHideFullScreenLoading();

if(!err.response.status) {

return false;

}

switch(err.response.status) {

case 504:

Message.error({message:'服務(wù)器被吃了⊙﹏⊙∥' });

break;

case 404:

Message.error({message:'服務(wù)器被吃了⊙﹏⊙∥' });

break;

case 403:

Message.error({message:'權(quán)限不足,請(qǐng)聯(lián)系管理員!' });

break;

default:

return Promise.reject(err);

}

})

axios.defaults.timeout =300000;// 請(qǐng)求超時(shí)5fen

export const postJsonRequest = (url, params) => {

return axios({

method:'post',

url: url,

data: params,

headers: {

'Content-Type':'application/json',

},

});

}

export const postRequest = (url, params) => {

return axios({

method:'post',

url: url,

data: params,

transformRequest: [function (data) {

let ret =''

? ? ? for (let it in data) {

ret +=encodeURIComponent(it) +'=' +encodeURIComponent(data[it]) +'&'

? ? ? }

return ret

? ? }],

headers: {

'Content-Type':'application/x-www-form-urlencoded'

? ? }

});

}

export const getRequest = (url, data ='') => {

return axios({

method:'get',

params: data,

url: url,

});

}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容